代码:
import timedef A(): while 1: print('------A-----') time.sleep(0.1) yield()def B(): while 1: print('-------B-----') time.sleep(0.1) next(a)a = A()B()
执行结果:
-------B-----------A------------B-----------A------------B-----------A------------B-----------A------------B-----------A-----···
上代码:
from greenlet import greenletimport timedef A(): while 1: print('-------A-------') time.sleep(0.5) g2.switch()def B(): while 1: print('-------B-------') time.sleep(0.5) g1.switch()g1 = greenlet(A) #创建协程g1g2 = greenlet(B)g1.switch() #跳转至协程g1
执行结果:
-------A--------------B--------------A--------------B--------------A-------···
上代码:
import geventdef A(): while 1: print('-------A-------') gevent.sleep(1) #用来模拟一个耗时操作,注意不是time模块中的sleepdef B(): while 1: print('-------B-------') gevent.sleep(0.5) #每当碰到耗时操作,会自动跳转至其他协程g1 = gevent.spawn(A) # 创建一个协程g2 = gevent.spawn(B)g1.join() #等待协程执行结束g2.join()
执行结果:
-------A--------------B--------------B--------------A--------------B--------------B--------------A--------------B--------------B-------···
import geventfrom gevent import monkey,socketmonkey.patch_all() #有IO才做时需要这一句s = socket.socket(2,1) #用的都是gevent模块中的socket,但用法一样s.setsockopt(1,2,1)s.bind(('',8080))s.listen(1024)def func_accept(): while 1: cs,userinfo = s.accept() print('来了一个客户'+str(userinfo)) g = gevent.spawn(func_recv,cs) #每当有用户连接,增加一条协程def func_recv(cs): while 1: recv_data = cs.recv(1024) print(recv_data) #程谁堵塞了,便会跳转至其他协程 if len(recv_data) > 0: cs.send(recv_data) else: cs.close() breakg1 = gevent.spawn(func_accept)g1.join()
联系客服