关于协程的简介
协程与线程的区别:
协程的本质是个单线程,单线程中可以存在多个协程。
协程的解析: 在执行A函数的时候,可以随时中断,去执行B函数,然后中断继续执行A函数(可以自动切换),这个过程并不是函数调用(没有调用语句),过程很像多线程,然而协程只有一个线程在执行
协程特点: 协程有自己的寄存器上下文和栈,调度切换回来时,会进入上一次离开时所处逻辑流的位置。
优点:
- 无需线程上下文切换的开销
- 方便切换控制流,简化编程模型
- 高并发+高扩展性+低成本:一个CPU支持上万的协程都不是问题。所以很适合用于高并发处理。
- 不需要锁的机制,只有一个线程,也不存在同时写变量冲突,在控制共享资源时也不需要加锁。
下面我们从代码中去理解,示例:
import gevent
def task1():
print('输出:==1==')
gevent.sleep(5)
print('输出:==2==')
def task2():
print('输出:==3==')
gevent.sleep(10)
print('输出:==4==')
if __name__ == '__main__':
# 创建协程并行执行程序
gevent.joinall([
gevent.spawn(task1),
gevent.spawn(task2),
])
打印的结果:
立刻打印:
输出:==1==
输出:==3==
5秒之后打印:
输出:==2==
10秒之后打印:
输出:==4==