-
生成器两种方法:
1.列表生成式将[]变成()
2.在函数中间加断点
next:一步一步执行生成器中的数
send:使用send()唤醒程序执行,使用send的好处是可以唤醒的同时向断点中传入一个符加的数据进程,线程,一个进程生成多个线程。
生成器的应用:实现多任务
协程:类似于两个while,True一起执行
先让t1运行议会,当t1遇到yield的时候,再返回到18行
然后执行t2,当它遇到yield的时候,再次切换到t1中
这一t1/t2/t1/t2的交替运行,最终实现了多任务并行(真的):两个任务,两个cpu,一个任务占用一个cpu
并发(假的):四个任务,两个cpu,四个任务交替占用cpu执行 -
生成器实现多任务:
代码:
import time
def task_1():
while True:
print("hello")
time.sleep(0.1)
yield
def task_2():
while True:
print('world')
time.sleep(0.1)
yield
def main():
s1 = task_1()
s2 = task_2()
while True:
next(s1)
next(s2)
main()
测试运行:
- yield实现单线程并发
利用了关键字yield一次性返回一个结果,阻塞,重新开始
send 唤醒
代码:
import time
def consumer(name):
print('%s 准备学习了~' %(name))
while True:
lesson = yield
print('开始[%s]了,[%s]老师来讲课了~' %(lesson,name))
def producer(name):
c1 = consumer('A')
c2 = consumer('B')
c1.__next__()
c2.__next__()
print('同学们开始上课了~')
for i in range(10):
time.sleep(1)
print('到了两个同学')
c1.send(i)
c2.send(i)
producer('westos')
编译运行: