我最近遇到了scala-pickling,我正在尝试如何在项目中使用它,所以我一直在使用一个带有不可变哈希图的case类的简单示例。在本例中,scala-pickling不会生成unpickler,我不知道为什么。以下是演示该问题的REPL会话:
scala> case class Foo(a: HashMap[Symbol,Symbol], b: HashMap[Symbol,Double], c: Symbol, d: Double)
defined class Foo
scala> val bar = Foo(new HashMap[Symbol,Symbol](), new HashMap[Symbol,Double](), 'A, 1.4)
bar: Foo = Foo(Map(),Map(),'A,1.4)
scala> val pickled = bar.pickle
pickled: scala.pickling.json.JSONPickle =
JSONPickle({
"tpe": "Foo",
"c": {
"name": "A"
},
"d": 1.4,
"a": {
},
"b": {
}
})
scala> val unpickled = pickled.unpickle[Foo]
<console>:18: error: Cannot generate an unpickler for Foo. Recompile with -Xlog-implicits for details
val unpickled = pickled.unpickle[Foo]有谁能指出我做错了什么吗?或者,scala酸洗有什么问题吗?
编辑:实际上,当我生成一个只有一个符号的属性的类时,似乎也会发生同样的事情(我将发布另一个REPL会话)。在scala中有没有一种特殊的方式来处理符号--酸洗?
scala> case class Foo(symb: Symbol)
defined class Foo
scala> val foo = Foo('A)
foo: Foo = Foo('A)
scala> val pick = foo.pickle
pick: scala.pickling.json.JSONPickle =
JSONPickle({
"tpe": "Foo",
"symb": {
"name": "A"
}
})
scala> val unpick = pick.unpickle[Foo]
<console>:17: error: Cannot generate an unpickler for Foo. Recompile with -Xlog-implicits for details
val unpick = pick.unpickle[Foo]发布于 2015-05-26 08:59:09
我知道这是一个古老的帖子,但请尝试
import scala.pickling._, Defaults._, json._https://stackoverflow.com/questions/21111276
复制相似问题