加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

序列化 – 为什么使用Scala RemoteActors设置类加载器?

发布时间:2020-12-16 18:15:02 所属栏目:安全 来源:网络整理
导读:使用 Scala RemoteActors时,我得到了一个引用scala.actors.remote.NetKernel的ClassNotFoundException.我复制了别人的例子并将RemoteActor.classLoader = getClass.getClassLoader添加到我的Actor中,现在一切正常.为什么这有必要? 解决方法 Remote Actors使
使用 Scala RemoteActors时,我得到了一个引用scala.actors.remote.NetKernel的ClassNotFoundException.我复制了别人的例子并将RemoteActor.classLoader = getClass.getClassLoader添加到我的Actor中,现在一切正常.为什么这有必要?

解决方法

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

希望有所帮助!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读