协程是什么?
协程又称为微线程,协程的完成主要靠yeild关键字,协程执行过程中,在子程序内部可中断,然后转而执行别的子程序,在适当的时候再返回来接着执行,注意,在一个子程序中中断,去执行其他子程序,不是函数调用,有点类似CPU的中断
协程的特点在于是一个线程执行,那和多线程比,协程有何优势?
最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。
因为协程是一个线程执行,那怎么利用多核CPU呢?最简单的方法是多进程+协程,既充分利用多核,又充分发挥协程的高效率,可获得极高的性能
下面是一个简单的协程
def run1():
while True:
print("Tell me to your heart")
time.sleep(1)
yield 1
def run2():
while True:
print("Tell me to your soul")
time.sleep(1)
yield 1
if __name__ == '__main__':
t1 = run1()
t2 = run2()
while True:
next(t1)
next(t2)
运行结果如下:
Tell me to your heart
Tell me to your soul
Tell me to your heart
Tell me to your soul
……
send关键字的用法
"""
这里yield 1整体被视为一个表达式,你send的内容会作为这个表达式的值,随便你左边
用什么东西接收或者不接收,总之yield就是你send进来的那个东西。这个表达式变成你
send进来后的东西后继续执行,再次遇到yield,输出yield后面跟着的表达式。
当然通常使用的话都不会输出一个常量,会输出一个和接收到的东西相关的量,不然岂不是
白白发送了
"""
def gen():
while True:
rec = yield 1
print("extra" + str(rec))
g = gen()
print(g)
print(next(g))
print(g.send(111))
print(next(g))
运行结果如下:
<generator object gen at 0x00000243E3D3AC50>
1
extra111
1
extraNone
1