Scala future 应用程序在完成之前终止
只是试图让我的第一个 future 使用并运行并进行类似于 Akka in Action MEAP 书中概述的示例的测试。我想调用 Web 服务并在将来返回结果。我正在使用 scalaxb 访问网络服务。我已经概述了下面的代码,但是当我运行它时,应用程序会终止而无需等待服务的响应。也许有人可以告诉我我错过了什么?
import scala.util._
import control.NonFatal
import scala.concurrent._
import ExecutionContext.Implicits.global
object Test {
val service = (new MyServiceBindings with scalaxb.Soap11Clients with scalaxb.DispatchHttpClients {}).service
def test = {
val f = future {
service.someCall() match {
case Right(resp) => resp
case Left(fault) => throw new Exception("Fault: " + fault)}
}
}
f.onComplete {
case Success(resp) => println("Resp: " + resp)
case Failure(NonFatal(e)) => println("Fail: " + e)
}
}
def main(args: Array[String]): Unit = {
test
}
}
请您参考如下方法:
它终止是因为在您的测试中执行的主线程已经完成。 Dispatch 库内部使用的线程不会阻止程序退出。
您需要等待 future ,因为这是您的测试应用程序正在做的唯一事情。把它放在 onComplete 语句之后。import scala.concurrent.duration._ Await.ready(f, 10.seconds)
现在请记住,这通常是不好的做法。你在这里需要它,因为你的测试应用程序没有做任何其他事情,但在一个真正的应用程序中,你不想在每次 future 调用之后阻塞,因为这会否定使用 future 的意义。
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。