【PYTHON模块】:协程与greenlet、gevent
admin
2023-07-24 16:22:45
0

协程:又称为微线程,英文名称Coroutine。

作用:它拥有自己的寄存器上下文和栈,能保留上一次调用时的状态,可以随时暂停程序,随时切换回来。

优点:

    •无需线程上下文切换的开销
    •无需原子操作锁定及同步的开销  

    •方便切换控制流,简化编程模型
    •高并发+高扩展性+低成本:一个CPU支持上万的协程都不是问题。所以很适合用于高并发处理

缺点:
    •无法利用多核资源:协程的本质是个单线程,它不能同时将 单个CPU 的多个核用上,协程需要和进程配合才能运行在多CPU上
    •进行阻塞(Blocking)操作(如IO时)会阻塞掉整个程序

 


  • 使用yield实现协程:

def g(name):
 print("starting product ....")
 while True:
  baozi= yield  # 程序暂停等待next
  print("{} is eating {}...".format(name,baozi))
def p():
 conn.__next__()  # 实例conn启动yield
 conn2.__next__() # 实例conn2启动yield
 i = 0
 while i<5:
  i += 1
  print("product: {}".format(i))  
  conn.send(i) # 向yield发送数据,yield恢复,并自动执行next
  conn2.send(i) # 向yield发送数据,yield恢复,并自动执行next

conn = g("laoda")  # 创建实例conn
conn2 = g("laoer")      # 创建实例conn2
product = p()   # 启动函数p

 



 

  • 使用greenlet实现协程:不是python自带模块,需要安装

        创建协程对象的方法其实有两个参数”greenlet(run=None, parent=None)”。参数”run”就是其要调用的方法,比如上例中的函数test1()和test2();参数”parent”定义了该协程对象的父协程,也就是说,greenlet协程之间是可以有父子关系的。如果不设或设为空,则其父协程就是程序默认的”main”主协程。

from greenlet import greenlet
def test1():
    print(1)
    t2.switch()    # 函数暂停,切换到t2
    print(2)

def test2():
    print(3)
    t1.switch()    # 函数暂停,切换到t1
    print(4)
   
t1=greenlet(test1)    # test1生成greenlet对象
t2=greenlet(test2)    # test2生成greenlet对象
t1.switch()



  • 使用gevent实现协程:第三方库,需要安装

实现了异步I/O,操作

方法
参数
作用
示例
spawn(func,func_args)

func:加入gevent的函数名

func_args:函数参数

把函数,创建协程实例

joinall[spawn_list]
spawn_list:spawn方法列表

把创建的协程实例添加到异步列表

等待列表中的所有实例执行完毕


sleep(time)
time:时间(秒)
交出CPU控制权,时间为秒

getcurrent()
获取当前协程内存地址
from gevent import gevent
import random
def creat(num):
 wait_time = random.Randomint(0,num)
 gevent.sleep(wait_time)
 print("{} wait done!".format(gevent.getcrrent()))
 
gevent_list = []
for i in range(20):
 gevent_list.append(gevent.spawn(creat, i))
gevent.joinall(gevent_list)


#Socket并发:(未测试)
import gevent
import socket
class server(object):
 def __int__(self,ip,port,*args):
  self.server_in = socket.socket()
  self.server_in.bind(ip,port)
  self.server_in.listen(100)
  # self.spawn_list = []
  
 def run(self):
  client_spawn = []
  while True:
   conn,addr = self.server_in.accept()
   client_spawn.append(gevent.spawn(handler,conn))
  gevent.joinall(client_spawn)
  
  
 def handler(self,conn):
  while True:
   recv_data = conn.recv(1024)
   if recv_data = 'exit':
    conn.shutdown(socket.SHUT_WR)
    break
   print("recv:".format(recv_data))
   conn.send(recv_data.upper())

 

http://python.jobbole.com/86481/

 

协程详解

相关内容

热门资讯

美称设立军事协调小组协助落实美... △美国国务卿鲁比奥(资料图)当地时间6月26日,美国国务卿鲁比奥发布声明表示,当日,美国、黎巴嫩和以...
布基纳法索宣布与法国断交 △布基纳法索(资料图)当地时间6月26日,布基纳法索政府宣布,自当天起断绝与法国的外交关系。布政府表...
美以黎签署三方框架协议,细节披... 当地时间26日晚,一名以色列官员披露称,经过美国、以色列和黎巴嫩三方的会谈,三方代表当晚在美国签署了...
联合国官员:委内瑞拉强震后逾5... 财联社6月27日电,联合国分管人道主义事务的副秘书长兼紧急救援协调员汤姆·弗莱彻表示,在委内瑞拉发生...
伊朗否认伊美就霍尔木兹海峡问题... 当地时间26日,伊朗伊斯兰革命卫队发言人侯赛因·穆赫比表示,针对“伊朗与美国已就霍尔木兹海峡问题设立...
特朗普:伊朗违反了停火协议 财联社6月26日电,美国总统特朗普表示,美军击落了伊朗三架无人机。特朗普称伊朗在霍尔木兹海峡发动的无...
江阴祝塘:荣飞5G智能绿色工厂... 6月23日,江阴市祝塘镇重点数字化转型标杆项目——荣飞5G智能绿色工厂项目顺利完成主体封顶。该项目聚...
翔亚机械取得一种电梯按键专利,... 国家知识产权局信息显示,嘉兴市翔亚机械设备有限公司取得一项名为“一种电梯按键”的专利,授权公告号CN...
溧阳市博物馆一张展出照片被指系... 极目新闻记者 张奇 近日,有网友在社交网站反映,江苏常州溧阳市博物馆展出了使用AI技术生成的图片,其...
“我们不喜欢中国AI,因为不受... 【文/观察者网 王一】 “我不喜欢(中国的人工智能)的一点是,它完全是开源的,这意味着它很大程度上不...