生成器02

本文介绍了Python中通过生成器实现的并发执行,包括通过yield实现单线程并发,使用greenlet和gevent库实现协程。通过示例展示了如何下载第三方库、并发下载图片以及进程、线程和协程的对比。还探讨了高阶函数map()、reduce()、filter()和排序方法的应用。
摘要由CSDN通过智能技术生成

通过生成器交替执行两个函数

#并行:两个cpu分别执行两个进程
#并发:两个cpu交替执行四个进程

def a1():

while True:

print(’~~~~~~~~~~1’)
yield

def a2():

while True:

print(’~~~~~~~~~~~2’)
yield

def main():

l1=a1()
l2=a2()
while True:

next(l1)
next(l2)

main()

结果如下:

在这里插入图片描述

#yield中断了函数,当a1执行到yield时,中断a1函数,释放内存执行a2,当a2执行到yield时中断a2,释放内存并执行a1。
a1,a2交替执行就实现多任务------协程

yield实现单线程并发

def a(name):

print(‘马什么梅,%s’ %name)
while True:

amd=yield
print(’%s什么冬梅,%s马冬什么’%(name,amd))

def main():

l1=a(‘马冬梅’)
l2=a(‘刘冬梅’)
l1.next()
l2.next()
for amd in range(10):

l1.send(amd)
l2.send(amd)

main()

结果展示:
在这里插入图片描述

#利用了关键词yield一次性返回一个结果,中断,next重新开始
send 唤醒

通过网络下载第三方库模块

/usr/loacl/python3/bin/pip3 install gevent #通过网络下载gevent模块

通过greenlet实现协程

简单了解下

from greenlet import greenlet
import time
def test1():

while True:

print(’-----A-----’)
gr2.switch()
time.sleep(0.5)

def test2():

while True:

print(’----B----’)
gr1.switch()
time.sleep(0.5)

gr1=greenlet(test1)
gr2=greenlet(test2)

gr1.switch()

通过手动.switch()来使两个函数互相调用来实现协程,手动通过gr1.switch()开始执行

结果展示:
在这里插入图片描述

通过gevent实现协程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值