python 协程
协程是什么,好处
线程和进程的操作是由程序触发系统接口,最后的执行者是系统;协程的操作则是程序员。
协程存在的意义:对于多线程应用,CPU通过切片的方式来切换线程间的执行,线程切换时需要耗时(保存状态,下次继续)。协程,则只使用一个线程,在一个线程中规定某个代码块执行顺序。
协程的适用场景:当程序中存在大量不需要CPU的操作时(IO),适用于协程;
event loop是协程执行的控制点, 如果你希望执行协程, 就需要用到它们。
event loop提供了如下的特性:
注册、执行、取消延时调用(异步函数)
创建用于通信的client和server协议(工具)
创建和别的程序通信的子进程和协议(工具)
把函数调用送入线程池中
yield的协程
实例:
import time
def work1():
for i in range(5):
print('work1', i)
yield
time.sleep(0.1)
def work2():
for i in range(5):
print('work2', i)
yield
time.sleep(0.1)
if __name__ == '__main__':
w1 = work1()
w2 = work2()
while True:
next(w1)
next(w2)
greenlet协程
实例:
import time
from greenlet import greenlet
def work1():
for i in range(5):
print('work1', i)
time.sleep(0.1)
g2.switch()
def work2():
for i in range(5):
print('work2', i)
time.sleep(0.1)
g1.switch()
if __name__ == '__main__':
g1 = greenlet(work1)
g2 = greenlet(work2)
# 这个是手动切换
g1.switch()
gevent协程–常用
实例
import time
import gevent
from gevent import monkey
# 这个代码必须先写,先执行
# 作用:给所以耗时操作打补丁,用于协程之间自动切换
monkey.patch_all()
def work1():
for i in range(5):
print('work1', i)
time.sleep(0.1)
def work2():
for i in range(5):
print('work2', i)
time.sleep(0.1)
if __name__ == '__main__':
g1 = gevent.spawn(work1)
g2 = gevent.spawn(work2)
g1.join()
g2.join()
exit()