加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

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

发布时间:2020-12-17 00:17:09 所属栏目:Python 来源:网络整理
导读:协程,又称微线程。英文名Coroutine。 协程最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。 第二大优势就是不需要多线程的锁机制,因为

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

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

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

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

进程相关请看

线程相关请看

</span><span style="color: #0000ff;"&gt;while</span><span style="color: #000000;"&gt; True: bone </span>= <span style="color: #0000ff;"&gt;yield</span> <span style="color: #0000ff;"&gt;print</span>(<span style="color: #800000;"&gt;"</span><span style="color: #800000;"&gt;[%s] 正在使用 %s</span><span style="color: #800000;"&gt;"</span> %<span style="color: #000000;"&gt; (name,bone))

<span style="color: #0000ff;">def<span style="color: #000000;"> producer(obj1,obj2):
obj1.send(None)
obj2.send(None)
n =<span style="color: #000000;"> 0
<span style="color: #0000ff;">while n < 5<span style="color: #000000;">:
n += 1
<span style="color: #0000ff;">print(<span style="color: #800000;">"<span style="color: #800000;">[producer]正在生产 %s<span style="color: #800000;">" %<span style="color: #000000;"> n)
obj1.send(n)
obj2.send(n)

<span style="color: #0000ff;">if <span style="color: #800080;">name == <span style="color: #800000;">'<span style="color: #800000;">main<span style="color: #800000;">'<span style="color: #000000;">:
con1 = consumer(<span style="color: #800000;">"<span style="color: #800000;">consumerA<span style="color: #800000;">"<span style="color: #000000;">)
con2 = consumer(<span style="color: #800000;">"<span style="color: #800000;">consumerB<span style="color: #800000;">"<span style="color: #000000;">)
producer(con1,con2)

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

greenlet <span style="color: #0000ff;">def<span style="color: #000000;"> producer():
<span style="color: #0000ff;">while
1<span style="color: #000000;">:
<span style="color: #0000ff;">print(<span style="color: #800000;">'<span style="color: #800000;">生产一件商品<span style="color: #800000;">'<span style="color: #000000;">)
time.sleep(0.5<span style="color: #000000;">)
g2.switch()

<span style="color: #0000ff;">def<span style="color: #000000;"> consumer():
<span style="color: #0000ff;">while 1<span style="color: #000000;">:
<span style="color: #0000ff;">print(<span style="color: #800000;">'<span style="color: #800000;">使用一件商品<span style="color: #800000;">'<span style="color: #000000;">)
time.sleep(0.5<span style="color: #000000;">)
g1.switch()

g1 = greenlet(producer) <span style="color: #008000;">#<span style="color: #008000;">创建协程g1
g2 =<span style="color: #000000;"> greenlet(consumer)

g1.switch()

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

<span style="color: #0000ff;">def<span style="color: #000000;"> competitor1():
<span style="color: #0000ff;">print(<span style="color: #800000;">"<span style="color: #800000;">competitor1:我开始吃了<span style="color: #800000;">"<span style="color: #000000;">)
gevent.sleep(1<span style="color: #000000;">)
<span style="color: #0000ff;">print(<span style="color: #800000;">"<span style="color: #800000;">competitor1:我吃完了<span style="color: #800000;">"<span style="color: #000000;">)

<span style="color: #0000ff;">def<span style="color: #000000;"> competitor2():
<span style="color: #0000ff;">print(<span style="color: #800000;">"<span style="color: #800000;">competitor2:我开始吃了<span style="color: #800000;">"<span style="color: #000000;">)
gevent.sleep(2<span style="color: #000000;">)
<span style="color: #0000ff;">print(<span style="color: #800000;">"<span style="color: #800000;">competitor2:我吃完了<span style="color: #800000;">"<span style="color: #000000;">)

gr1=<span style="color: #000000;">gevent.spawn(competitor1)
gr2=<span style="color: #000000;">gevent.spawn(competitor2)

gevent.joinall([gr1,gr2])

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读