为什么使用Scala RemoteActors设置类加载器?

Cra*_*lin 5 serialization scala classloader remote-actors

使用Scala RemoteActors时,我得到了一个引用scala.actors.remote.NetKernel的ClassNotFoundException.我复制了别人的例子,并添加RemoteActor.classLoader = getClass.getClassLoader到我的演员,现在一切正常.为什么这有必要?

jsu*_*eth 5

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 所使用的所有类的类加载器.

希望有所帮助!