协程的作用 Python
1.协程的含义和实现
协程是单进程单线程的超越函数的调度机制,它通过一定的调度手段进行调度。
(Python使用generator机制,greenlet使用汇编控制对程序指向来实现)。
2.协程有什么作用
计算机分为IO bound 和CPU bound两种类型的task。在这两种情况中,协程都没有什么作用。
为什么?
在CPU bound task中,cpu被用来执行任务去了。这类task,即使一个一个方法的执行,跟协程的效率还要高出一点点,使用协程没有意义。IO bound task中,CPU已经陷入系统调用之中,用户空间的调度无论如何也是没有CPU的,这样情况下,协程只能死死的。在这样情况下,祈求高效率,怎么可能。
协程只有在非常有限制的情况下,才有一些用处,在单进程单线程任务中的交互青霞,才有它的用武之地。
3.协程不是未来(反驳赖勇浩)。协程是很早之前就有的。很早之前,windows就有纤程的概念,Linux不太确定。但是它一直作为小众的API而存在。
4.协程的两个评测:
import gevent
import random
import time def task(pid):
"""
Some non-deterministic task
"""
for i in range(1000):
random.randint(0,20) def synchronous():
for i in range(1,10000):
task(i) def asynchronous():
threads = [gevent.spawn(task, i) for i in xrange(10000)]
gevent.joinall(threads) print('Synchronous:')
t = time.time()
synchronous()
diff = time.time() -t
print "diff is %f" %diff print('Asynchronous:')
t = time.time()
asynchronous()
diff = time.time() -t
print "diff is %f" %diff
结果:
Synchronous:
diff is 22.333482
Asynchronous:
diff is 22.422071
2.IO bound
import gevent.monkey
gevent.monkey.patch_socket() import gevent
import urllib2
import time def fetch(pid):
response = urllib2.urlopen('http://127.0.0.1:8080/')
result = response.read() return result def synchronous():
for i in range(1,100):
fetch(i) def asynchronous():
threads = []
for i in range(1,100):
threads.append(gevent.spawn(fetch, i))
gevent.joinall(threads) print('Synchronous:')
t = time.time()
synchronous()
diff = time.time() - t
print "diff is %f" %diff print('Asynchronous:')
t = time.time()
asynchronous()
diff = time.time() - t
print "diff is %f" %diff
结果为:
Synchronous:
diff is 0.791572
Asynchronous:
diff is 0.997519
上述例子结果只是单次运行结果,跟使用机器相关性很大。
5.gevnet+flask是一个很流行的用法,但是gevent真正有用的是libev,它是使用epoll(linux), kqueue(bsd),IOCP(windows)实现network IO,并在轮询处理signal,signal,callback的lib。
end。。。。。。一家之言,欢迎拍砖。。
协程的作用 Python的更多相关文章
- [转载]Python 3.5 协程究竟是个啥
http://blog.rainy.im/2016/03/10/how-the-heck-does-async-await-work-in-python-3-5/ [译] Python 3.5 协程究 ...
- [译] Python 3.5 协程究竟是个啥
转自:http://blog.rainy.im/2016/03/10/how-the-heck-does-async-await-work-in-python-3-5/ [译] Python 3.5 ...
- Python 协程 61
什么是协程 协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程. 协程的特点 协程拥有自己的寄存器上下文和栈.协程调度切换时,将寄存器上下文和栈保存到 ...
- Python协程(真才实学,想学的进来)
真正有知识的人的成长过程,就像麦穗的成长过程:麦穗空的时候,麦子长得很快,麦穗骄傲地高高昂起,但是,麦穗成熟饱满时,它们开始谦虚,垂下麦芒. --蒙田<蒙田随笔全集> *** 上篇论述了关 ...
- Python并发编程系列之协程
1 引言 协程是近几年并发编程的一个热门话题,与Python多进程.多线程相比,协程在很多方面优势明显.本文从协程的定义和意义出发,结合asyncio模块详细讲述协程的使用. 2 协程的意义 2.1 ...
- Python 进阶 之 协程
协程的概念级描述(与线程对比):转自知乎 链接 线程有两个必须要处理的问题:一是碰着阻塞式I\O会导致整个进程被挂起: 二是由于缺乏时钟阻塞,进程需要自己拥有调度线程的能力. 如果一种实现使得每个线程 ...
- Python 协程与事件循环
Table of Contents 前言 协程 async & await 事件循环 asyncio 的事件循环 结语 参考链接 前言 Python 标准库 asyncio 是我目前接触过的最 ...
- Python实现协程
什么是进程和线程 有一定基础的小伙伴们肯定都知道进程和线程. 进程是什么呢? 直白地讲,进程就是应用程序的启动实例.比如我们运行一个游戏,打开一个软件,就是开启了一个进程. 进程拥有代码和打开的文件资 ...
- Python异步IO之协程(一):从yield from到async的使用
引言:协程(coroutine)是Python中一直较为难理解的知识,但其在多任务协作中体现的效率又极为的突出.众所周知,Python中执行多任务还可以通过多进程或一个进程中的多线程来执行,但两者之中 ...
随机推荐
- 【转载】zookeeper 分布式锁 实现
agapple 基于zookeeper的分布式lock实现 博客分类: opensource java distributed 背景 继续上一篇文章:http://agapple.iteye. ...
- Linq左右連接
1.左连接: var LeftJoin = from emp in ListOfEmployeesjoin dept in ListOfDepartmenton emp.DeptID equals d ...
- Ubuntu12.04-64bits搭建FFmpeg环境
所有的环境搭建动作请参考FFMpeg官方网站:http://www.ffmpeg.org/index.html 1. 获取源代码: git clone git://source.ffmpeg.org/ ...
- 数据库分页--MySQL数据库
关于实现MySQL分页的最简单的方法就是利用mysql数据库的limit函数:limit [offset,] rows SELECT * FROM 表名称 LIMIT M,N limit 子句可以被用 ...
- linux内核--几个上下文(context)
为了控制进程的执行,内核必须有能力挂起正在CPU上运行的进程,并恢复以前挂起的某个进程的执行,这种行为叫进程切换(process switch),任务切换(task switch)或上下文切换(con ...
- linux内核数据结构--进程相关
linux里面,有一个结构体task_struct,也叫“进程描述符”的数据结构,它包含了与进程相关的所有信息,它非常复杂,每一个字段都可能与一个功能相关,所以大部分细节不在我的研究范围之内,在这篇文 ...
- 反射——类(Class)
本文原创,转载请注明原处! 红色代表的是基本组件:包(Package),修饰符(modifier),类(Class),字段(Field),构造器(Constructor)和方法(Method). 黄色 ...
- 23讲 URL2
这是关于URL路由的小笔记. 为什么用使用URL路由呢? 我的想法是:用户在地址栏可以乱传参数,所以我们必须最出一些防范措施,防止出现用户看到的不友好界面. 例如地址栏的地址为:http://loca ...
- FolderBrowserDialog
FolderBrowserDialog folderBrowserDialog1 = new FolderBrowserDialog(); folderBrowserDial ...
- 使用Inputstream读取文件
在java中,能够使用InputStream对文件进行读取,就是字节流的输入.当读取文件内容进程序时,须要使用一个byte数组来进行存储,如此会有例如以下两个问题: 1.怎样建立合适大小的byte数组 ...