如何从akka future获取值onComplete回调的成功和失败块

时间:2015-12-30 10:51:25

标签: java scala akka scala-2.11 scala-2.12

我有一个代码,我正在检查演员是否不存在我们将创建它但问题是我的代码使用未来的OnComplete回调,我在函数/ def中这样做我只是想返回ActorRef这里是我的代码

def getRegularAdminIndexMongoActor():ActorRef= {
        var actorRef:ActorRef=null
    val sel = actorSystem.actorSelection("akka://ActorSystem/user/RegularAdminIndexMongoActor");
     val future:Future[ActorRef] = sel.resolveOne().mapTo[ActorRef] 
     future.onComplete { 
          case Success(result)=>  
          if(result != null){
            log.info("actor exists" + result)
          }
          actorRef=result
          actorRef
         case Failure(e)=>
           log.warn("in failure block actor does not exists" + e)
           val regularAdminIndexMongoActor=system.actorOf(Props[RegularAdminIndexMongoActor],name = "RegularAdminIndexMongoActor")
           log.info("created a new one "+regularAdminIndexMongoActor.path.toString())
           actorRef=regularAdminIndexMongoActor      
     }
log.info("whats is in actorRef " + actorRef)
     actorRef
         }

我正在调用这样的代码

log.info("getting ref"+getRegularAdminIndexMongoActor)

and the output is 
15:33:39.082 555049 [play-internal-execution-context-1] Global$ INFO - whats in actorRef null
15:33:39.082 555049 [play-internal-execution-context-1] Global$ INFO - getting ref null
15:33:39.083 555050 [play-internal-execution-context-1] play INFO - Application started (Dev)
15:33:39.151 555118 [ForkJoinPool-4-worker-7] Global$ INFO - actor exists Actor[akka://ActorSystem/user/RegularAdminIndexMongoActor#-1022921773]

我怎么能得到实际的ActorRef它给我null但是actor正在创建并且我试图通过这样做将ref存储在两个块中

actorRef=result //success block
actorRef=regularAdminIndexMongoActor //failure block

我认为它在调用onComplete之前返回值并返回null,因为我在my函数的开头初始化了变量null如何解决这个问题?请帮助我如何实现我想要的ActorRef

1 个答案:

答案 0 :(得分:0)

actorRef是一个var,它将在sel.resolveOne()完成之前被分配,这可能在你返回值之前。如果你真的想以你的方式做你正在做的事情,你可以使用

import scala.concurrent._
import scala.concurrent.duration._

Await.result(f,Duration(6000,"millis"))

Await结果将阻止,直到将来传递或6秒后。

现在,像其他人一样,这不是一个好主意。

因为您似乎正在创建这个演员,所以您可以直接访问孩子

val child = child(name)
child.getOrElse(getContext().actorOf(..., name))