美文网首页
python基础 -- 协程continue

python基础 -- 协程continue

作者: fada492daf5b | 来源:发表于2018-01-27 22:14 被阅读0次

1.协程

利用异步,用最少的资源做最多的事

2. 操作

# 协程coroutine

# yield 生成器
def func():
    while True:
        x = yield
        print('x ==> {}...'.format(x))

g = func()

# g.send('开始吧')
# TypeError: can't send non-None value to a just-started generator
# 原因没有启动生成器

# 启动生成器g
# 程序运行到yield,等待下一次运行
next(g) # 或者g.send(None)
# 发送数据
g.send(1) 
g.send('我的天吶。。。')
g.send(g)
# 没有发送数据,但是仍然在yield处
next(g)
g.send(None)

# 两个函数之间传递数值
def consumer():
    r = ''
    while True:
        n = yield r # 弹出r,返回n
        if not n:
            print('我爱你')
            return
        print('[Consumer] consuming {}...'.format(n))
        r = '200 Ok'

def produce(c):
    c.send(None) 
    n = 0
    while n < 5:
        n = n + 1
        print('[Producer] producing {}...'.format(n))
        r = c.send(n) # 给comsumer发送n
        print('[Producer] consumer return: {}...'.format(r))
    c.close()

c = consumer() # 生成一个生成器
produce(c)

# 利用装饰器开启协程
def deco(func):
    def wrapper(*args, **kwagrs):
        gene = func(*args, **kwagrs)
        next(gene) # 启动
        return gene
    return wrapper

@deco
def coroutine():
    n = 0
    while True:
        print('start coroutine {}...'.format(n))
        r = yield n
        print('ended coroutine {}...\n'.format(n))
        n += 1

c = coroutine()
for i in range(10):
    print(c.send(i))

# yield from
# 调用生成器generator
def copy_corontine():
    print('start yield from...')
    r = yield from coroutine()
    print('ended yield from...')

# for i in copy_corontine():
#     print(i)



# 异步IO
# asyncio
import asyncio

@asyncio.coroutine
def hello():
    print("Hello World!")
    # 异步调用asyncio.sleep(1)
    # asyncio.sleep()也是coroutine
    # yield from 调用generator
    r = yield from asyncio.sleep(1)
    print("Hello again!")

# 获取Eventloop:
loop = asyncio.get_event_loop()
loop.run_until_complete(hello())
# loop.close()

# asyncio.wait 分发任务
@asyncio.coroutine
def wget(host):
    print('Wget {}...'.format(host))
    connect = asyncio.open_connection(host, 80)
    reader, writer = yield from connect
    header = 'GET / HTTP/1.0\r\nHost: {}\r\n\r\n'.format(host)
    writer.write(header.encode('utf-8'))
    yield from writer.drain()
    while True:
        line = yield from reader.readline()
        if line == b'\r\n':
            break
        print('{} header > {}'.format(host, 
            line.decode('utf-8').rstrip()))
    writer.close()

# loop = asyncio.get_event_loop()
tasks = [wget(host) for host in ['www.sina.com.cn', 'www.sohu.com', 'www.163.com']]
loop.run_until_complete(asyncio.wait(tasks))
# loop.close()

# async/await替代@asyncio.coroutine/await
# @asyncio.coroutine
# def love_me_as_i_go():
#     print('follow me')
#     r = yield from asyncio.sleep(1)
#     print('forget me')

async def love_me_as_i_go():
    print('follow me')
    r = await asyncio.sleep(1)
    print('forget me')

love = love_me_as_i_go()
loop.run_until_complete(love)

相关文章

  • python基础 -- 协程continue

    1.协程 利用异步,用最少的资源做最多的事 2. 操作

  • python异步协程(aiohttp,asyncio)

    python异步协程 环境:python3.7.0 协程 协程,英文叫做 Coroutine,又称微线程,纤程,协...

  • Python 协程的基本概念

    Python 协程的基本概念 在学习 Python 基础的过程中,遇到了比较难理解的地方,那就是协程。刚开始看了廖...

  • AndroidのKotlin协程

    参考资料:协程基础 1.协程Coroutines基础 1.1 GlobalScope.launch启动一个独立协程...

  • asyncio + asyncio 异步编程实例

    协程用法 接下来,我们来了解下协程的实现,从 Python 3.4 开始,Python 中加入了协程的概念,但这个...

  • Python 协程

    仅供学习,转载请注明出处 协程 协程,又称微线程,纤程。英文名Coroutine。 协程是啥 协程是python个...

  • 协程

    1.协程 协程,又称微线程,纤程。英文名Coroutine。 1.1 协程是什么 协程是python个中另外一种实...

  • Python并发编程——协程

    摘要:Python,协程,gevent 协程基本概念 协程,又称微线程,纤程。英文名Coroutine,是Pyth...

  • 协程介绍

    协程 协程,又称微线程,纤程。英文名Coroutine。 1.协程是什么? 协程是python个中另外一种实现多任...

  • 4-7

    协程 协程,又称微线程,纤程。英文名Coroutine。 协程是啥 协程是python个中另外一种实现多任务的方式...

网友评论

      本文标题:python基础 -- 协程continue

      本文链接:https://www.haomeiwen.com/subject/vftoaxtx.html