scala - 自动将 JavaBeans 包装/转换为 case 类

标签 scala

我们使用 Kryo 在 Scala 应用程序和 Java 应用程序之间进行通信。由于必须从 Java 中使用类定义(并且我们不想将 Scala 库作为依赖项包含在 Java 应用程序中),因此我们使用 JavaBeans 来定义传输对象。

但是,在 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 */ }
}

这是我们用来桥接到 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)
}

由于我们所有的对象都有时间戳,它也是样板的一部分。我们想要某种方式(也许是一个宏?)来自动生成 unapply 和 apply 方法(理想情况下是整个对象本身)。

有谁知道一种简单的方法来实现这一目标?

最佳答案

由于没有答案,我想出了这个:https://github.com/yetu/scala-beanutils .

关于scala - 自动将 JavaBeans 包装/转换为 case 类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29678937/

相关文章:

scala - 你如何处理 Akka Flow 中的 futures 和 mapAsync?

Scala 变量参数 :_*

scala - Scala 中的简单税收计算

javascript - 如何使用 jQuery 在动态生成的 scala 模板列表中查找嵌套元素?

java - 如何优化 Spark RDD 上的 groupBy() 操作

ajax - SCALA Lift - AJAX 形成多个值

Java LinkedHashMap 到 scala Map 转换及递归转换

scala - 什么是 TypeTag 以及如何使用它?

java - 如何在 Scala 中将案例类转换为 Json-LD?

scala - 是否可以使用延续使foldRight尾递归?