python基础学习22----协程

python基础学习22----协程,第1张

概述协程,又称微线程。英文名Coroutine。 协程最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就

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

协程最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。

第二大优势就是不需要多线程的锁机制,因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。

因为协程是一个线程执行,那怎么利用多核cpu呢?最简单的方法是多进程+协程,既充分利用多核,又充分发挥协程的高效率,可获得极高的性能。

进程相关请看

线程相关请看

</span><span https://m.jb51.cc/tag/color/" target="_blank" >color</a>: #0000ff;"&gt;while</span><span https://m.jb51.cc/tag/color/" target="_blank" >color</a>: #000000;"&gt; True: bone </span>= <span https://m.jb51.cc/tag/color/" target="_blank" >color</a>: #0000ff;"&gt;y<a href="https://m.jb51.cc/tag/IE/" target="_blank" >IE</a>ld</span> <span https://m.jb51.cc/tag/color/" target="_blank" >color</a>: #0000ff;"&gt;print</span>(<span https://m.jb51.cc/tag/color/" target="_blank" >color</a>: #800000;"&gt;"</span><span https://m.jb51.cc/tag/color/" target="_blank" >color</a>: #800000;"&gt;[<a href="https://www.jb51.cc/tag/s/" target="_blank" >%s</a>] 正在<a href="https://m.jb51.cc/tag/shiyong/" target="_blank" >使用</a> <a href="https://www.jb51.cc/tag/s/" target="_blank" >%s</a></span><span https://m.jb51.cc/tag/color/" target="_blank" >color</a>: #800000;"&gt;"</span> %<span https://m.jb51.cc/tag/color/" target="_blank" >color</a>: #000000;"&gt; (<a href="https://m.jb51.cc/tag/name/" target="_blank" >name</a>,bone))

<span >def<span > producer(obj1,obj2):
obj1.send(None)
obj2.send(None)
n =<span > 0
<span >while n < 5<span >:
n += 1
<span >print(<span >"<span >[producer]正在生产 %s<span >" %<span > n)
obj1.send(n)
obj2.send(n)

<span >if <span >name == <span >'<span >main<span >'<span >:
con1 = consumer(<span >"<span >consumerA<span >"<span >)
con2 = consumer(<span >"<span >consumerB<span >"<span >)
producer(con1,con2)

greenlet进行手动切换实现协程,切换的方式是switch

greenlet <span >def<span > producer():
<span >while
1<span >:
<span >print
(<span >'
<span >生产一件商品<span >'<span >)
time.sleep(0.5<span >)
g2.switch()

<span >def<span > consumer():
<span >while 1<span >:
<span >print(<span >'<span >使用一件商品<span >'<span >)
time.sleep(0.5<span >)
g1.switch()

g1 = greenlet(producer) <span >#<span >创建协程g1
g2 =<span > greenlet(consumer)

g1.switch()

Gevent是一种基于协程的Python网络库,它用到Greenlet提供的,封装了libevent事件循环的高层同步API。它让开发者在不改变编程习惯的同时,用同步的方式写异步I/O的代码

<span >def<span > competitor1():
<span >print(<span >"<span >competitor1:我开始吃了<span >"<span >)
gevent.sleep(1<span >)
<span >print(<span >"<span >competitor1:我吃完了<span >"<span >)

<span >def<span > competitor2():
<span >print(<span >"<span >competitor2:我开始吃了<span >"<span >)
gevent.sleep(2<span >)
<span >print(<span >"<span >competitor2:我吃完了<span >"<span >)

gr1=<span >gevent.spawn(competitor1)
gr2=<span >gevent.spawn(competitor2)

gevent.joinall([gr1,gr2])

gevent.sleep()是模拟IO阻塞,如果所有子程序都进入IO阻塞则等待最先完成阻塞的子程序,之后进入该子程序执行。

总结

以上是内存溢出为你收集整理的python基础学习22----协程全部内容,希望文章能够帮你解决python基础学习22----协程所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1208199.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存