gpt4 book ai didi

Scala Actor 阻塞当前线程

转载 作者:行者123 更新时间:2023-12-05 00:33:38 26 4
gpt4 key购买 nike

我尝试基于 Scala 的 actor API 实现一个计时器,其中当前的 Thread actor (Actor.self) 作为计时器和一个匿名 Actor 来完成需要及时完成的​​工作。
我有以下 Scala 程序

import scala.actors.Actor.self
import scala.actors.TIMEOUT

object Main {
def main(args: Array[String]): Unit = {
val thiz = self
actor {
// do heavy work here
thiz ! "finish"
}
self.reactWithin(1000) {
case "finish" => println("complete")
case TIMEOUT => println("timeout")
}
}
}

当我运行程序时,我收到了
Exception in thread "main" scala.actors.SuspendActorControl
scala.actors.ActorProxy@1d99a4d: caught java.lang.InterruptedException

请告诉我解决问题的方法。

最佳答案

您有两种类型的控制传递与 scala-actor,线程阻塞 线程悬挂 .后者意味着抛出一个控制异常(线程再次可供线程池管理器使用),并且当消息进入其邮箱时重新执行actor主体。见 actors tutorial有关更多详细信息,尤其是部分“让它无线程!”。
receiveWithin方法使用线程阻塞,而reactWithin暂停。您在这里遇到的问题是没有捕获异常的外部管理参与者。这仅适用于“适当的”actor,不适用于为主线程创建的代理。所以如果你想在显式actor外等待主线程,你需要使用线程阻塞/receiveWithin :

self.receiveWithin(1000) { ... }

关于Scala Actor 阻塞当前线程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11677584/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com