什么是协程

协程又叫做微线程,它是在单一线程内通过不断切换执行的。协程的切换不是上下文的切换也就是说不是CPU的执行任务的切换,比如CPU执行一会线程1,然后再执行一会线程2,在多核CPU上,Python由于有GIL,所以它的切换是核心1上的线程1执行一会,然后核心2上的线程2执行一会。协程是单线程的也就是线程这种东西是在单一线程内部,协程的切换也是在线程内部切换的,它切换的是执行流,所以本质上线程内的所有协程执行是顺序的那也就是意味着某个协程阻塞会阻塞整个线程,这也就是为什么说协程切换没有开销同时不需要锁的原因,同时也就是说明了协程本身无法利用多核资源,因为它依附于线程而线程本身它自己也只能跑在一个核心上,那么要想并发就只能多进程加协程。

还记的之前的例子么

#!/usr/bin/env python
# -*- coding: utf-8 -*- def consumer(name, pices):
print("--->[%s]等待骨头,请喂我 %d 块。" % (name, pices))
eaten = 0
while True:
# 第一次调用这个函数将返回一个生成器而不是真正执行这里面的方法,只有调这个生成器的next方法才会执行。
# yield 可以返回数据,我这里没有返回。程序走到这里遇到yield就返回了,这里为什么赋值给一个变量呢,因为可以接收数据。
# 返回后程序就停在这里了。只有当唤醒send之后才会执行下面的打印语句。
bone = yield
if eaten == pices:
print("[%s] 我已经吃饱了。" % name)
else:
print("[%s] 吃了 %s 块骨头。" % (name, bone))
eaten += 1
print("[%s] 我已经吃了 %d 块骨头。" % (name, eaten))
# time.sleep(1) def producer():
# 通过对生成器调用 next()的时候才会执行
next(petDog1)
next(petDog2)
n = 0
while n < 10:
n += 1
print("\033[32;1m[主人]\033[0m 丢 %s 块骨头。" % 1)
# send是唤醒生成器,也就是让函数继续执行,这里输入一个参数,表示激活这个生成器的时候给它传递一个变量进去,本例就是上面的 bone 这个变量,丢一块骨头
petDog1.send(1)
petDog2.send(1) if __name__ == '__main__':
# 函数里面有 yield 第一次调用这个函数它返回的是一个生成器,所以第一次不执行
petDog1 = consumer("金毛", 10)
petDog2 = consumer("泰迪", 3)
master = producer()

这个使用了yeild的例子就是协程的概念。通过yeild定义生成器,通过next和send不断在两个狗之间切换。这里呢其实是手动切换在实际当中应该是自动切换,因为每个狗吃骨头的时间不同,大狗吃的快小狗吃的慢。

gevent

这是一个第三方库,实现了单一线程内的多个执行流协作调度。

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Author: rex.cheny
# E-mail: rex.cheny@outlook.com def task1():
print('\033[31;1m task1 \033[0m running...')
gevent.sleep(2) # 模仿IO操作的时间
print('\033[31;1m task1 \033[0m continue running...') def task2():
print('\033[32;1m task2 \033[0m running...')
gevent.sleep(1) # 模仿IO操作的时间
print('\033[32;1m task2 \033[0m continue running...') gevent.joinall([
gevent.spawn(task1),
gevent.spawn(task2),
])

这个过程它实现了在两个任务之间进行切换而且是自动的并没有手动控制。

spawn实现了事件注册,而join实现了事件的轮询。通过gevent加上socket可以实现并发异步socket。

对gevent详细说明

对greenlet详细说明

Python的协程的更多相关文章

  1. python gevent 协程

    简介 没有切换开销.因为子程序切换不是线程切换,而是由程序自身控制,没有线程切换的开销,因此执行效率高, 不需要锁机制.因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断 ...

  2. 深入理解Python中协程的应用机制: 使用纯Python来实现一个操作系统吧!!

    本文参考:http://www.dabeaz.com/coroutines/   作者:David Beazley 缘起: 本人最近在学习python的协程.偶然发现了David Beazley的co ...

  3. 关于Python的协程问题总结

    协程其实就是可以由程序自主控制的线程 在python里主要由yield 和yield from 控制,可以通过生成者消费者例子来理解协程 利用yield from 向生成器(协程)传送数据# 传统的生 ...

  4. {python之协程}一 引子 二 协程介绍 三 Greenlet 四 Gevent介绍 五 Gevent之同步与异步 六 Gevent之应用举例一 七 Gevent之应用举例二

    python之协程 阅读目录 一 引子 二 协程介绍 三 Greenlet 四 Gevent介绍 五 Gevent之同步与异步 六 Gevent之应用举例一 七 Gevent之应用举例二 一 引子 本 ...

  5. 【Python】协程

    协程,又称微线程,纤程.英文名Coroutine. 协程的概念很早就提出来了,但直到最近几年才在某些语言(如Lua)中得到广泛应用. 子程序,或者称为函数,在所有语言中都是层级调用,比如A调用B,B在 ...

  6. Python之协程(coroutine)

    Python之协程(coroutine) 标签(空格分隔): Python进阶 coroutine和generator的区别 generator是数据的产生者.即它pull data 通过 itera ...

  7. python的协程和_IO操作

    协程Coroutine: 协程看上去也是子程序,但执行过程中,在子程序内部可中断,然后转而执行别的子程序,在适当的时候再返回来接着执行. 注意,在一个子程序中中断,去执行其他子程序,不是函数调用,有点 ...

  8. python 3 协程函数

    python 3 协程函数 1:把函数的执行结果封装好__iter__和__next__,即得到一个迭代器 2:与return功能类似,都可以返回值,但不同的是,return只能返回一次值,而yiel ...

  9. Python之协程函数

    Python之协程函数 什么是协程函数:如果一个函数内部yield的使用方法是表达式形式的话,如x=yield,那么该函数成为协程函数. def eater(name): print('%s star ...

  10. 多任务-python实现-协程(2.1.11)

    多任务-python实现-协程(2.1.11) 23/100 发布文章 qq_26624329 @ 目录 1.概念 2.迭代器 1.概念 协程与子例程一样,协程(coroutine)也是一种程序组件. ...

随机推荐

  1. Linux之环境搭建(二)

    上一节介绍了PC机安装Ubuntu,本节来看看Ubuntu下安装VMWare,以及在VMWare中安装Windows10. 原本想使用免费的VMware Workstation Player 15,但 ...

  2. 计蒜客 买书 dfs

    题目: https://www.jisuanke.com/course/2291/182236 思路: 递归解决,从第一本书开始,每本书都有两种选择: //index是book里面每本书价格的下标, ...

  3. 生产环境,vue页面跳转的时候,js报404的问题

    最近上线的一个vue项目,需要各种路由跳转,在开发和测试环境都没问题,但是在生产环境,发现后期更新代码的时候,有些机型(ios机型,暂未发现android有问题)跳转路由的时候,标题修改了,但是内容并 ...

  4. JS实现快速排序,冒泡排序

    JS-排序详解-冒泡排序   说明 时间复杂度指的是一个算法执行所耗费的时间 空间复杂度指运行完一个程序所需内存的大小 稳定指,如果a=b,a在b的前面,排序后a仍然在b的前面 不稳定指,如果a=b, ...

  5. Ext使用中问题总结

    隐藏 Ext.form.DateField 的触发(trigger)元素使其内容不能修改并使其所有的文本框(text field)显示格式为Y-m-d items : [{ xtype : ' dat ...

  6. PCB Mark点相关

    1)Mark点用于锡膏印刷和元件贴片时的光学定位.根据Mark点在PCB上的作用,可分为拼板Mark点.单板Mark点.局部Mark点(也称器件级MARK点) 2)拼板的工艺边上和不需拼板的单板上应至 ...

  7. 如何删除github上的某个文件夹

    在github上只能删除仓库,却无法删除文件夹或文件, 所以只能通过命令来解决 首先进入你的master文件夹下, Git Bash Here ,打开命令窗口 $ git –help 帮助命令 $ g ...

  8. GLOG使用Demo

    GLOG使用Demo GLOG是Google开源的一个精简的日志系统,博主简单学习了一下并记录常见用法,以备日常查询 一.安装 照例是编译安装,不过没有使用cmake git clone https: ...

  9. 在Linux上搭建测试环境常用命令(转自-测试小柚子)

    一.搭建测试环境: 二.查看应用日志: (1)vivi/vim 原本是指修改文件,同时可以使用vi 日志文件名,打开日志文件(2)lessless命令是查看日志最常用的命令.用法:less 日志文件名 ...

  10. 大数据计算框架Hadoop, Spark和MPI

    转自:https://www.cnblogs.com/reed/p/7730338.html 今天做题,其中一道是 请简要描述一下Hadoop, Spark, MPI三种计算框架的特点以及分别适用于什 ...