python协程代理实现有环的协程间消息传递

本文介绍了如何使用Python协程处理计算拓扑中的环形结构,通过消息缓冲进行协程间的数据传递。示例展示了协程b和c如何交互,其中b接收到a发送的数值,并将处理后的结果传递给c。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

python协程是个不错的东东,如果计算拓扑中有环的话可以通过消息缓冲实现。

from collections import deque

class delegate:
    '''协程函数代理,有代理后协程间的关系允许有环'''
    def __init__(self,func):
        '''初始化,func为协程函数,将创建消息缓冲队列'''
        self.msgbuf = deque()
        self.func = func
    def __call__(self,*args,**kwargs):
        '''启动协程'''
        self.funcgen = self.func(*args,**kwargs)
        return self.funcgen
    def send(self,msg):
        '''对协程send消息的代理函数'''
        try:
            #先发送队列中的消息,之后发送新消息
            while len(self.msgbuf) > 0:
                self.funcgen.send(self.msgbuf[0])
                self.msgbuf.popleft()
            self.funcgen.send(msg)
        except ValueError:
            #发送失败则将新消息加入队列
            self.msgbuf.append(msg)
        except StopIteration:
            self.stop()
    def stop(self):
        '''最后需将队列中的消息发出'''
        while len(self.msgbuf) > 0:
            self.funcgen.send(self.msgbuf[0])
            self.msgbuf.popleft()

def coroutine(func):
    '''协程的修饰函数,修饰后不需调用next'''
    def newfunc(*args,**argss):
        generator = func(*args,**argss)
        generator.next()
        return generator
    return newfunc

#例子 a -> b -> c-> b,消息在b、c间来回转发

def ag(outstream):
   for i in range(3):
       outstream.send( ("a",i) )

@coroutine
def bg(outstream):
    while True:
        src, msg = (yield)
        print "b received:",src,msg
        if src != "c":
            outstream.send( ("b",(src,msg)) )

@coroutine
def cg(outstream):
    while True:
        src, msg = (yield)
        print "c received:",src,msg
        outstream.send( ("c",(src,msg)) )

bd=delegate(bg) #创建b的代理对象
c=cg(bd)    #用b的代理对象初始化c
b=bd(c)     #有c后初始化b
a=ag(bd)    #用b的代理初始化a,a启动发布数据
bd.stop()   #通知b的代理结束,缓冲区的数据继续发完

结果:

b received: a 0
c received: b ('a', 0)
b received: c ('b', ('a', 0))
b received: a 1
c received: b ('a', 1)
b received: c ('b', ('a', 1))
b received: a 2
c received: b ('a', 2)
b received: c ('b', ('a', 2))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值