scala – Akka:在Actor中一次处理一条消息的原因是什么?
发布时间:2020-12-16 18:44:11 所属栏目:安全 来源:网络整理
导读:据说: Akka ensures that each instance of an actor runs in its own lightweight thread and that messages are processed one at a time. 您能否解释一下在演员中一次处理一条消息的原因是什么? 解决方法 这样我们就可以保证Actor内部的线程安全. 因为a
据说:
您能否解释一下在演员中一次处理一条消息的原因是什么? 解决方法
这样我们就可以保证Actor内部的线程安全.
因为actor在任何给定时间只会处理一条消息,所以我们可以保证访问actor的本地状态是安全的,即使Actor本身可能正在切换它正在执行的Threads. Akka保证处理消息M1时写入的状态一旦处理M2就可以被Actor看到,即使它现在可以在不同的线程上运行(通常保证这种安全性需要付出巨大的代价,Akka会为你处理这个) . 它也源于原始的Actor模型描述,它是一种并发抽象,被描述为只能逐个处理消息并通过执行以下操作之一来响应这些操作的actor:发送其他消息,更改其行为或创建新actor. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |