因为我处理的是泛型类型,所以我不能使用特定的案例类。然后,我创建了一个泛型util,它序列化和反序列化泛型对象。
import org.json4s
import org.json4s.Formats._
import org.json4s.native.JsonMethods._
object JsonHelper {
def json2Object[O](input: String) : O = {
parse(json4s.string2JsonInput(input)).asInstanceOf[O]
}
def object2Json[O](input: O) : String = {
write(input).toString
}
}编译器抛出错误:
没有为类型O找到JSON序列化程序。尝试为该类型实现隐式Writer或JsonFormat。写入(输入).toString
这应该在运行时抛出,但是为什么在编译时抛出呢?
发布于 2016-10-31 12:21:41
在上面的评论中,您问到“那么jackson如何使用java对象?它使用反射吗?为什么它与Scala不同?”,而Scala正是这个问题的核心。
您导入的json4s“本机”序列化程序使用编译时反射来创建Writer。
杰克逊使用运行时反射来做同样的事情。
编译时版本更高效;运行时版本更灵活。
要使用编译时版本,需要让编译器获得足够的信息,以便根据要序列化的对象的声明类型选择正确的Writer。这将排除像您建议的那种非常通用的编写方法。关于如何修复该版本的代码,请参见@TimP的答案。
要使用运行时版本,可以通过org.json4s.jackson.JsonMethods._包使用Jackson。请参阅https://github.com/json4s/json4s#jackson
发布于 2016-10-30 13:54:28
您发布的编译器错误来自在json4s代码中的这个位置。您正在调用的write函数采用隐式JSON Writer,这就是该方法可以采取任意类型的方式。它是在编译时捕获的,因为隐式参数的编译方式与显式参数的编译方式相同--就好像您有:
def f(a: Int, b: Int) = a + b
f(5) // passed the wrong number of arguments我很难看清您在这里调用的是哪个write方法-- json4s库非常大,而且负载过重。您能粘贴您正在使用的声明的write方法吗?它几乎可以肯定有这样的签名:
def write[T](value: T)(implicit writer: Writer[T]): JValue如果如下所示,尝试在方法中包括隐式编写器参数,如下所示:
object JsonHelper {
def json2Object[O](input: String)(implicit reader: Reader[O]) : O = {
parse(json4s.string2JsonInput(input)).asInstanceOf[O]
}
def object2Json[O](input: O)(implicit writer: Writer[O]) : String = {
write(input).toString
}
}发布于 2016-10-26 14:56:47
在本例中,您需要处理泛型类型,Scala和另一种jvm语言一样,在编译时具有type erasing机制(编译时的错误消息可能不包含关于泛型的整体消息),因此尝试将此片段添加到这两种方法的签名中:
(implicit tag: ClassTag[T])它是与泛型示例相似,但与jackson相似。HTH
https://stackoverflow.com/questions/39901526
复制相似问题