python actor_Actor模式——Python实现及应用

“并发是一种解耦策略” —— Robert C.Martin何为Actor模式呢?在计算机科学中,参与者模式(Actor model)是一种并发运算上的模型。“参与者”是一种程序上的抽象概念,被视为并发运算的基本单元:当一个参与者接收到一则消息,它可以做出一些决策、创建更多的参与者、发送更多的消息、决定要如何回答接下来的消息。这段话很全面,但也需要我们花时间来消化与理解。不妨先试着阅读以...
摘要由CSDN通过智能技术生成

“并发是一种解耦策略”      —— Robert C.Martin

何为Actor模式呢?

在计算机科学中,参与者模式(Actor model)是一种并发运算上的模型。“参与者”是一种程序上的抽象概念,被视为并发运算的基本单元:当一个参与者接收到一则消息,它可以做出一些决策、创建更多的参与者、发送更多的消息、决定要如何回答接下来的消息。

这段话很全面,但也需要我们花时间来消化与理解。不妨先试着阅读以下这段Python代码实现,再分析理解。

from queue import Queue

from threading import Thread

class ActorExit(Exception):

pass

class Actor(object):

def __init__(self):

self._thread = Thread()

self._queue = Queue()

def send(self, msg):

self._queue.put(msg)

def receive(self):

msg = self._queue.get()

if msg is ActorExit:

raise ActorExit()

return msg

def stop(self):

if self._thread.is_alive():

self.send(ActorExit)

def start(self):

if not self._thread.is_alive():

self._thread = Thread(target=self.

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值