时间:2021-05-23
greenlet示例
greenlet微线程,允许在线程中手动切换
示例1,线程切换
from greenlet import greenletdef test1(x,y): z = gr2.switch(x+y) print(z)def test2(u): print(u) gr1.switch(42)gr1 = greenlet(test1)gr2 = greenlet(test2)gr1.switch("hello",'world')gr1和gr2是两个greenlet线程,使用gr1.switch(..)启动gr1,gr1执行test1,切换到gr2,gr2执行test2打印helloworld,然后切换回gr1,z获取
到返回值42,并打印.
执行顺序为:
gr1.switch("hello",'world') -> test1('hello','world')->
gr2.switch('helloword')->test2('helloworld')->print('helloworld')
->gr1.switch(42)->z=42->print(42)
打印结果:
helloworld
42
示例2
from greenlet import greenletdef eat(name): print('%s eat 1' %name) g2.switch('egon') print('%s eat 2' %name) g2.switch()def play(name): print('%s play 1' %name) g1.switch() print('%s play 2' %name)g1=greenlet(eat)g2=greenlet(play)g1.switch('egon')#可以在第一次switch时传入参数,以后都不需要g1.switch('egon')#可以在第一次switch时传入参数,以后都不需要
gevent
gevent基于greenlet,遇到IO操作自动切换,IO操作比如网络请求,或使用 gevent.sleep(0)强制切换.
示例1
import geventdef func1(): print("start func1") gevent.sleep(1) print("end func1")def func2(): print("start func2") gevent.sleep(1) print("end func2")gevent.joinall( [ gevent.spawn(func1), gevent.spawn(func2) ])执行结果:
start func1
start func2
end func1
end func2
``
示例2: gevent使用monkey对所有系统自带的IO操作打patch
执行结果
eat food 1
play 1
play 2
eat food 2
end
示例3,发送请求
from gevent import monkey; monkey.patch_all()import geventimport requestsdef f(url): print('GET: %s' % url) resp = requests.get(url) data = resp.text print('%d bytes received from %s.' % (len(data), url))gevent.joinall([ gevent.spawn(f, 'https://']jobs = [gevent.spawn(socket.gethostbyname, url) for url in urls]gevent.joinall(jobs, timeout=2)print([job.value for job in jobs])或使用patch_socket()from gevent import monkey; monkey.patch_socket()import geventdef f(n): for i in range(n): print(gevent.getcurrent(), i) gevent.sleep(0) # 不加的话不会交替执行g1 = gevent.spawn(f, 5)g2 = gevent.spawn(f, 5)g3 = gevent.spawn(f, 5)g1.join()g2.join()g3.join()示例5:队列中使用gevent.sleet(0)强制切换到其他线程
import geventfrom gevent.queue import Queuedef func(): for i in range(10): print("int the func") q.put(f"test{i}") gevent.sleep(0)def func2(): for i in range(10): print("int the func2") res = q.get() print("--->",res)q = Queue()gevent.joinall( [ gevent.spawn(func2), gevent.spawn(func), ])以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
这篇文章主要介绍了python基于gevent实现并发下载器代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以
这篇文章主要介绍了python模块和包的应用BASE_PATH使用解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可
这篇文章主要介绍了Python解析json代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下什么是j
这篇文章主要介绍了Python使用Pandas读写Excel实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以
这篇文章主要介绍了python使用opencv在Windows下调用摄像头实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,