gpt4 book ai didi

java - 将 java enum 转换为 scala Enumeration 以进行 json4s 序列化

转载 作者:行者123 更新时间:2023-12-02 05:11:51 25 4
gpt4 key购买 nike

我正在使用json4s将 scala 案例类转换为 json 消息的库。我的案例类依赖于第三方 java 枚举类型:

//third party java code
public enum Fruit {
Banana (1),
Cherry (2);
}

然后我的 scala 类使用此枚举作为参数:

case class Order(fruit : Fruit, quantity : Int)

我正在尝试use EnumNameSerializer由“org.json4s.ext”库提供:

import org.json4s._
import org.json4s.native.Serialization
import org.json4s.native.Serialization.{write, read}
import org.json4s.ext.EnumNameSerializer

case class Order(fruit : Fruit, quantity : Int) {
implicit lazy val formats =
DefaultFormats + new EnumNameSerializer(fruit)
}

但是,我遇到了编译时错误:

error: inferred type arguments [Fruit] do not conform to class EnumNameSerializer's type parameter bounds [E <: Enumeration]

如何将 java 枚举转换为 json4s 的 EnumNameSerializer 的 scala 枚举?

我希望避免写 custom serializer因为我的实际用例涉及我的案例类中使用的许多不同的 java 枚举类型,因此我必须编写许多不同的自定义序列化器。

预先感谢您的考虑和回复。

最佳答案

这样的东西对你有用吗?

class EnumSerializer[E <: Enum[E]](implicit ct: Manifest[E]) extends CustomSerializer[E](format ⇒ ({
case JString(name) ⇒ Enum.valueOf(ct.runtimeClass.asInstanceOf[Class[E]], name)
}, {
case dt: E ⇒ JString(dt.name())
}))



// first enum I could find
case class X(a: String, enum: java.time.format.FormatStyle)
implicit val formats = DefaultFormats + new EnumSerializer[java.time.format.FormatStyle]()

// {"a":"test","enum":"FULL"}
val jsonString = Serialization.write(X("test", FormatStyle.FULL))
Serialization.read[X](jsonString)

关于java - 将 java enum 转换为 scala Enumeration 以进行 json4s 序列化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35847377/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com