详解Python中的协程

python

线程和进程的操作是由程序触发系统接口,最后的执行者是系统;协程的操作则是程序员。

协程存在的意义:对于多线程应用,CPU通过切片的方式来切换线程间的执行,线程切换时需要耗时(保存状态,下次继续)。协程,则只使用一个线程,在一个线程中规定某个代码块执行顺序。

协程的适用场景:当程序中存在大量不需要CPU的操作时(IO),适用于协程;

event loop是协程执行的控制点, 如果你希望执行协程, 就需要用到它们。

event loop提供了如下的特性:

注册、执行、取消延时调用(异步函数)

创建用于通信的client和server协议(工具)

创建和别的程序通信的子进程和协议(工具)

把函数调用送入线程池中

协程示例:

import asyncio

   

async def cor1():

    print("COR1 start")

    await cor2()

    print("COR1 end")

   

async def cor2():

    print("COR2")

   

loop = asyncio.get_event_loop()

loop.run_until_complete(cor1())

loop.close()

最后三行是重点。

asyncio.get_event_loop()  : asyncio启动默认的event loop 

run_until_complete()  :  这个函数是阻塞执行的,知道所有的异步函数执行完成,

close()  :  关闭event loop。

1、greenlet

import greenlet

def fun1():

    print("12")

    gr2.switch()

    print("56")

    gr2.switch()

  

def fun2():

    print("34")

    gr1.switch()

    print("78")

  

  

gr1 = greenlet.greenlet(fun1)

gr2 = greenlet.greenlet(fun2)

gr1.switch()

2、gevent

gevent属于第三方模块需要下载安装包

pip3 install --upgrade pip3

pip3 install gevent

import gevent

  

def fun1():

    print("www.baidu.com")   # 第一步

    gevent.sleep(0)

    print("end the baidu.com")  # 第三步

  

def fun2():

    print("www.zhihu.com")   # 第二步

    gevent.sleep(0)

    print("end th zhihu.com")  # 第四步

  

gevent.joinall([

    gevent.spawn(fun1),

    gevent.spawn(fun2),

])

遇到IO操作自动切换:

import gevent

import requests

def func(url):

    print("get: %s"%url)

    gevent.sleep(0)

    date =requests.get(url)

    ret = date.text

    print(url,len(ret))

gevent.joinall([

    gevent.spawn(func, 'https://www.pythontab.com/'),

    gevent.spawn(func, 'https://www.yahoo.com/'),

    gevent.spawn(func, 'https://github.com/'),

])


以上是 详解Python中的协程 的全部内容, 来源链接: utcz.com/z/524082.html

回到顶部