我正在关注scala object serialization 的基本示例。但是,在运行以下单元测试时
package mytest
import java.io.{ByteArrayOutputStream, ObjectOutputStream}
import org.scalatest.{Matchers, WordSpec}
class BasicSerializationSpec extends WordSpec with Matchers {
@SerialVersionUID(123L)
class TestRecord(var content: String) extends Serializable {
override def toString = s"TestRecord($content)"
}
"A TestRecord" should {
"be serializable" in {
val oo = new ObjectOutputStream(new ByteArrayOutputStream())
val tr = new TestRecord("42")
oo.writeObject(tr)
oo.close
}
}
}
我得到一个例外:
org.scalatest.Assertions$AssertionsHelper java.io.NotSerializableException:在 java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548) 在 java.io.ObjectOutputStream 的 java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)。 writeSerialData(ObjectOutputStream.java:1509) 在 java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432) 在 java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178) 在 java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java :1548) 在 java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1509) 在 java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432) 在 java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178) 在 java .io。ObjectOutputStream.writeObject(ObjectOutputStream.java:348) 在 mytest.BasicSerializationSpec.$anonfun$new$2(BasicSerializationSpec.scala:20)
我试图明确设置类型
val tr : java.io.Serializable = new TestRecord("42")
但仍然没有运气。
如何正确地将 scala 对象序列化为 java ObjectOutputStream?
这不是其他堆栈答案的重复,因为我显然在扩展Serializable我的类声明。
预先感谢您的考虑和回复。
跃然一笑
慕仙森
随时随地看视频慕课网APP
相关分类