我们使用 Kryo 在 Scala 应用程序和 Java 应用程序之间进行通信。由于必须从 Java 使用类定义(并且我们不想将 Scala 库作为 Java 应用程序中的依赖项包含在内),因此我们使用 JavaBean 来定义传输对象。
然而,在Scala中直接使用JavaBeans有点麻烦。没有模式匹配,必须使用 new 等。我们现在正在做的是定义提取器并在 Scala 端的单独对象中应用方法,以便更好地使用这些类。
由于我们需要的大部分内容都是样板文件,因此我们想知道是否有一种方法可以自动执行此操作。例如,我们有这个 JavaBean(大约有 20 多种不同的消息类型):
public class HandshakeRequest extends Request {
private String gatewayId;
private String requestId;
private Date timestamp = new Date();
public HandshakeRequest(String gatewayId, String requestId) {
this.gatewayId = gatewayId;
this.requestId = requestId;
}
public String getGatewayId() { return gatewayId; }
public String getRequestId() { return requestId; }
public Date getTimestamp() { return timestamp; }
private HandshakeRequest() { /* For Kryo */ }
}
Run Code Online (Sandbox Code Playgroud)
这是我们用来桥接到 Scala 的对象的示例:
object Handshake {
def unapply(msg: HandshakeRequest): Option[ (DateTime, String, String) ] = {
(
new DateTime(msg.getTimestamp.getTime),
msg.getRequestId,
msg.getGatewayId
).some
}
def apply(gatewayId: String, requestId: String) = new HandshakeRequest(gatewayId, requestId)
}
Run Code Online (Sandbox Code Playgroud)
由于我们所有的对象都有时间戳,它也是样板的一部分。我们想要某种方式(也许是宏?)来自动生成 unapply 和 apply 方法(理想情况下是整个对象本身)。
有谁知道一个简单的方法来完成这个任务?