3

我正在使用 Akka 2.2.0、Java 1.7.0_25 和 Eclipse Juno 重写客户端/服务器应用程序。

我有一个使用 Akka 2.0.2 的示例客户端和服务器。
我更新到旧的稳定版本 2.1.4 并再次让一切正常工作。我刚刚迁移到最新的稳定版本 2.2.0。

我创建了一个新包来添加一些新功能,而保留现有代码不变。发生了一些变化,现在我无法启动我的测试用例。

这是我在尝试创建 ActorSystem 时看到的堆栈跟踪:

Exception in thread "main" java.lang.ClassNotFoundException: [B
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
at akka.actor.ReflectiveDynamicAccess.getClassFor(DynamicAccess.scala:94)
at akka.serialization.Serialization$$anonfun$4.apply(Serialization.scala:154)
at akka.serialization.Serialization$$anonfun$4.apply(Serialization.scala:153)
at scala.collection.TraversableLike$WithFilter$$anonfun$map$2.apply(TraversableLike.scala:697)
at scala.collection.immutable.HashMap$HashMap1.foreach(HashMap.scala:178)
at scala.collection.immutable.HashMap$HashTrieMap.foreach(HashMap.scala:347)
at scala.collection.TraversableLike$WithFilter.map(TraversableLike.scala:696)
at akka.serialization.Serialization.<init>(Serialization.scala:153)
at akka.serialization.SerializationExtension$.createExtension(SerializationExtension.scala:15)
at akka.serialization.SerializationExtension$.createExtension(SerializationExtension.scala:12)
at akka.actor.ActorSystemImpl.registerExtension(ActorSystem.scala:644)
at akka.actor.ExtensionId$class.apply(Extension.scala:34)
at akka.serialization.SerializationExtension$.apply(SerializationExtension.scala:12)
at akka.remote.RemoteActorRefProvider.init(RemoteActorRefProvider.scala:77)
at akka.actor.ActorSystemImpl._start(ActorSystem.scala:568)
at akka.actor.ActorSystemImpl.start(ActorSystem.scala:575)
at akka.actor.ActorSystem$.apply(ActorSystem.scala:103)
at akka.actor.ActorSystem$.apply(ActorSystem.scala:98)
at akka.actor.ActorSystem$.create(ActorSystem.scala:64)
at akka.actor.ActorSystem.create(ActorSystem.scala)

它抱怨它无法通过方法描述符样式字符串“[B”加载字节数组。

@som-snytt 指出了两个错误报告,它们准确描述了我看到的错误。

@paul-vargas 调用 -Dsun.lang.ClassLoader.allowArraySyntax=true 重新启用旧的 loadClass 行为。

allowArraySyntax 标志确实使 ClassNotFoundException 消失,但弹出了其他错误。这些错误让我相信我的 Eclipse/m2e/Scala-ide/Akka 设置出了点问题。

我将项目导入 Netbeans 7.3 并进行了清理和构建,它在第一次尝试时就可以工作。我什至不需要设置allowArraySyntax。

4

3 回答 3

4

您是否需要将参数添加到 VM:

-Dsun.lang.ClassLoader.allowArraySyntax=true
于 2013-07-16T00:33:58.453 回答
2

这对每个人来说都不是新闻:

http://bugs.sun.com/view_bug.do?bug_id=6500212

http://bugs.sun.com/view_bug.do?bug_id=6434149

由于@paul-vargas,我才查到了这一点。

我观察到在主干中,建议ReflectiveDynamicAccess使用Class.forName错误报告中的内容。请参阅master 上的代码

您可能希望将 Akka 与 Java 版本一起升级。

或者,也许您的生产运行时卡在 1.5 上,但您在 1.7 上进行开发。

于 2013-07-16T07:42:14.357 回答
0

旧的 akka 和 scala jar 与更新版本一起位于类路径中。不知道为什么它会导致上述异常,但是一旦 Paul 指出 allowArraySyntax 标志,问题就变得很明显。

于 2013-07-18T17:42:07.923 回答