java - 如何在 Java 应用程序中使用 TypedActor?

标签 java actor akka typedactor

我尝试按照 Typed Actors (Java) 上的示例在 Java 中实现 TypedActor 。但我正在挣扎。我添加了 akka-actor-1.1-M1.jarakka-typed-actor-1.1-M1.jarscala-library.jar > 但这还不够。我在 Eclipse 中遇到错误,因此我还将 aspectwerkz-2.0.jaraspectwerkz-core-2.0.jar 添加到我的构建路径中。

我尝试使用带有自定义构造函数的 TypedActor。

但是现在我在编译时遇到错误:

Exception in thread "main" java.lang.NoSuchMethodError: org.codehaus.aspectwerkz.proxy.Proxy.newInstance([Ljava/lang/Class;[Ljava/lang/Object;ZZ)Ljava/lang/Object;
    at akka.actor.TypedActor$.newInstance(TypedActor.scala:596)
    at akka.actor.TypedActor$.newInstance(TypedActor.scala:634)
    at akka.actor.TypedActor.newInstance(TypedActor.scala)
    at com.example.actor.ActorTest.main(ActorTest.java:12)

这是我的BaseActor代码:

import akka.actor.TypedActor;

public class BaseActor extends TypedActor implements BaseService {

    private String str;
    private int num;

    public BaseActor(String str, int num) {
    this.str = str;
    this.num = num;
        System.out.println("booted");
    }

    public void testData(String str, int num) {
        System.out.println(this.str + " " + this.num);
        System.out.println(str + " " + num);
    }
}

我的服务界面:

public interface BaseService {

    public void testData(String str, int num);
}

还有一个测试类:

import akka.actor.TypedActor;
import akka.actor.TypedActorFactory;

public class ActorTest {

    public static void main(String[] args) {

        BaseService service = TypedActor.newInstance(BaseService.class,
                                                     new TypedActorFactory() {
            public TypedActor create() {
                return new BaseActor("someString", 12);
            }
        });

        service.testData("Hello", 6);
    }

}

在示例中他们写道:

Service service = TypedActor.newInstance(classOf[Service], 
                                         new TypedActorFactory() {
  public TypedActor create() {
    return new ServiceWithConstructorArgsImpl("someString", 500L));
});

但我不认为classOf[Service]是Java,它看起来更像Scala。

如何使用自定义构造函数实现 TypedActor

最佳答案

据我所知,您的代码是正确的。 要使用非默认构造函数在 Java 中实例化 TypedActor,您应该使用:

BaseService service = TypedActor.newInstance(BaseService.class,
                                                     new TypedActorFactory() {
            public TypedActor create() {
                return new BaseActor("someString", 12);
            }
        });

确实,官方文档存在拼写错误。

您可以尝试使用aspectwerkz-2.2.3吗?我已经尝试过你的代码,它对我有用。唯一的区别是我使用的aspectwerkz 版本。

另外,请注意这些是 akka-typed-actor 1.1-M1 的依赖项:

<dependency org="org.codehaus.aspectwerkz" name="aspectwerkz" rev="2.2.3" force="true" conf="compile->compile(*),master(*);runtime->runtime(*)"/>
<dependency org="aopalliance" name="aopalliance" rev="1.0" force="true" conf="compile->compile(*),master(*);runtime->runtime(*)"/>
<dependency org="org.guiceyfruit" name="guice-all" rev="2.0" force="true" conf="compile->compile(*),master(*);runtime->runtime(*)"/>
<dependency org="se.scalablesolutions.akka" name="akka-stm" rev="1.1-M1" force="true" conf="compile->compile(*),master(*);runtime->runtime(*)"/>
<dependency org="org.scala-lang" name="scala-library" rev="2.9.0.RC1" force="true" conf="compile->compile(*),master(*);runtime->runtime(*)"/>

关于java - 如何在 Java 应用程序中使用 TypedActor?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5829909/

相关文章:

java - keytool error keystore 被篡改,或密码不正确

java - 层列表形状 + 位图顶部有填充

java - 我怎样才能在这场线程竞赛中区分出胜利者呢?

exception - Service Fabric Actor 远程调用导致 "Specified cast is not valid."异常

java - Java 中的 Akka Actor 模型实现

java - 重命名所有变量和方法名称的脚本或工具有什么建议吗?

c# - Orleans grains 中的单线程

akka - akka 持久性是否比我在 redis 中存储消息状态更好?

scala - 如何在 Akka dispatcher 中使用自定义执行器

java - 识别 Akka Actors 的多个实例