Cra*_*lin 5 serialization scala classloader remote-actors
使用Scala RemoteActors时,我得到了一个引用scala.actors.remote.NetKernel的ClassNotFoundException.我复制了别人的例子,并添加RemoteActor.classLoader = getClass.getClassLoader
到我的演员,现在一切正常.为什么这有必要?
Remote Actors使用Java序列化来回发送消息.在actors库中,你会找到一个自定义对象输入流(https://lampsvn.epfl.ch/trac/scala/browser/scala/trunk/src/actors/scala/actors/remote/JavaSerializer.scala)用于将对象序列化到套接字或从套接字序列化对象.还有一些路由代码和其他魔术.
无论如何,用于远程处理的ClassLoader非常重要.如果您不熟悉它,我建议您查找Java RMI.在任何情况下,Scala在序列化/反序列化actor时选择的ClassLoader是位于RemoteActor上的一个默认为null的类.
这意味着默认情况下,如果不指定ClassLoader,您将会感到不快;).
如果您所在的环境控制类加载器(例如OSGi),则需要确保将此值设置为可以访问所有序列化actor 所使用的所有类的类加载器.
希望有所帮助!
归档时间: |
|
查看次数: |
1074 次 |
最近记录: |