0

我正在尝试使用 akka 在 java play2 中创建工作。

我总是遇到同样的错误error: cannot find symbol

它指向system.actorOf()Intellij 和 Eclipse 不要给我错误消息。

但我找不到这种方法。我使用了以下导入

import play.libs.Akka;
import akka.actor.ActorSystem;
import akka.actor.ActorRef;
import akka.actor.UntypedActorFactory;
import akka.actor.UntypedActor;
import akka.actor.Props;
import akka.actor.ActorRefFactory;

也许文档已经过时并且他们已经删除了system.actorOf()?

public class Global extends GlobalSettings {

    ActorRef tickActor = system.actorOf(new Props().withCreator(new UntypedActorFactory() {
          public UntypedActor create() {
            return new UntypedActor() {
              public void onReceive(Object message) {
                if (message.equals("Log")) {
                  controllers.Application.log();
                } else {
                  unhandled(message);
                }
              }
            };
          }
        }));

    @Override
    public void onStart(Application app) {
        Cancellable cancellable = system.scheduler().schedule(Duration.Zero(), Duration.create(10, TimeUnit.SECONDS),
                tickActor, "Log");

    }
}

编辑:

.

哦...谷歌将我重定向到过时的文档。现在是Akka.System()..

  • 谁能给我一个关于如何使用 up2date 代码创建 tickActor 的示例?

http://www.playframework.org/documentation/2.0.2/JavaAkka

4

2 回答 2

1

我强烈建议您查看有关actorschedulers的 Akka 文档。

你也可以看看这个问题:Play Framework 2.0 schedules an Akka Actor at server launch

于 2012-08-24T11:59:09.413 回答
1

解决了。

顺便说一句,文档中有一些错别字。

import java.util.concurrent.TimeUnit;

import play.*;
import play.mvc.*;
import play.mvc.Http.RequestHeader;

import static play.mvc.Results.*;
import play.libs.Akka;
import akka.actor.ActorSystem;
import akka.actor.ActorRef;
import akka.actor.UntypedActorFactory;
import akka.actor.UntypedActor;
import akka.actor.Props;
import akka.actor.ActorRefFactory;

import akka.util.*;
public class Global extends GlobalSettings {

    ActorRef tickActor;

    @Override
    public void onStart(Application app) {
        Logger.info("D");
        tickActor = Akka.system().actorOf((new Props().withCreator(new UntypedActorFactory() {
              public UntypedActor create() {
                    return new UntypedActor() {
                      public void onReceive(Object message) {
                        if (message.equals("Log")) {
                                 //Do something
                         // controllers.Application.log();
                        } else {
                          unhandled(message);
                        }
                      }
                    };
                  }
                })));
        Akka.system().scheduler().schedule(
                  Duration.create(0, TimeUnit.MILLISECONDS),
                  Duration.create(30, TimeUnit.MINUTES),
                  tickActor, 
                  "Log"
                );

    }



}
于 2012-08-24T12:02:59.983 回答