- 什么是协程:
协程又称微线程,用户级线程,是Python 中实现多任务的方式之一。
特点:在不开辟线程的基础上完成多任务
- 创建协程的方式
- 使用yield 即只要含有yield就是协程
import time
def task1():
while True:
print("--1--")
time.sleep(0.1)
yield
def task2():
while True:
print("--2--")
time.sleep(0.1)
yield
def main():
t1=task1()
t2=task2()
#先让t1运行,t1遇到yield的时候在返回,然后
#执行t2,当他遇到yield时候再次切换到t1
#这样交替运行,实现了多任务
while True:
next(t1)
next(t2)
if __name__=='__main__':
main()
- 使用分装好的包 gevent
当一个gevent遇到IO操作时,比如访问网络,就自动切换到其他的gevent,等到IO操作完成,再在适当的时候切换回来继续执行。由于IO操作非常耗时,经常使程序处于等待状态,有了gevent为我们自动切换协程,就保证总有greenlet在运行,而不是等待IO。
import gevent
from gevent import monkey
import time
#将程序中用到的耗时操作的代码,切换为gevent中自己实现的模块
monkey.patch_all()
def a():
for i in range(10):
print('a:',i)
time.sleep(0.8)
def b():
for i in range(10):
print('b:',i)
time.sleep(0.8)
ga=gevent.spawn(a)
gb=gevent.spawn(b)
#让线程等待所有任务完成,再继续执行
#ga.join()
#gb.join()
gevent.joinall(ga,gb)
- 进程、线程、协程
- 进程是系统资源分配的基本单位,线程是CPU调度的基本单位,协程是在不开辟线程的基础上完成多任务
- 进程资源开销大,稳定性强,效率很低;线程资源开销较小,稳定性较差,效率一般;协程资源开销小,稳定性依赖于线程,效率较高
- 多进程,多线程可能是并行,但协程在一个线程中,所以是并发
- 协程依赖于线程,线程依赖于进程。
总结:
协程最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。
第二大优势就是不需要多线程的锁机制,因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。
因为协程是一个线程执行,那怎么利用多核CPU呢?最简单的方法是多进程+协程,既充分利用核,又充分发挥协程的高效率,可获得极高的性能。