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的更多相关文章

  1. [转载]Python 3.5 协程究竟是个啥

    http://blog.rainy.im/2016/03/10/how-the-heck-does-async-await-work-in-python-3-5/ [译] Python 3.5 协程究 ...

  2. [译] Python 3.5 协程究竟是个啥

    转自:http://blog.rainy.im/2016/03/10/how-the-heck-does-async-await-work-in-python-3-5/ [译] Python 3.5 ...

  3. Python 协程 61

    什么是协程 协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程. 协程的特点 协程拥有自己的寄存器上下文和栈.协程调度切换时,将寄存器上下文和栈保存到 ...

  4. Python协程(真才实学,想学的进来)

    真正有知识的人的成长过程,就像麦穗的成长过程:麦穗空的时候,麦子长得很快,麦穗骄傲地高高昂起,但是,麦穗成熟饱满时,它们开始谦虚,垂下麦芒. --蒙田<蒙田随笔全集> *** 上篇论述了关 ...

  5. Python并发编程系列之协程

    1 引言 协程是近几年并发编程的一个热门话题,与Python多进程.多线程相比,协程在很多方面优势明显.本文从协程的定义和意义出发,结合asyncio模块详细讲述协程的使用. 2 协程的意义 2.1 ...

  6. Python 进阶 之 协程

    协程的概念级描述(与线程对比):转自知乎 链接 线程有两个必须要处理的问题:一是碰着阻塞式I\O会导致整个进程被挂起: 二是由于缺乏时钟阻塞,进程需要自己拥有调度线程的能力. 如果一种实现使得每个线程 ...

  7. Python 协程与事件循环

    Table of Contents 前言 协程 async & await 事件循环 asyncio 的事件循环 结语 参考链接 前言 Python 标准库 asyncio 是我目前接触过的最 ...

  8. Python实现协程

    什么是进程和线程 有一定基础的小伙伴们肯定都知道进程和线程. 进程是什么呢? 直白地讲,进程就是应用程序的启动实例.比如我们运行一个游戏,打开一个软件,就是开启了一个进程. 进程拥有代码和打开的文件资 ...

  9. Python异步IO之协程(一):从yield from到async的使用

    引言:协程(coroutine)是Python中一直较为难理解的知识,但其在多任务协作中体现的效率又极为的突出.众所周知,Python中执行多任务还可以通过多进程或一个进程中的多线程来执行,但两者之中 ...

随机推荐

  1. Problem 2214 Knapsack problem 福建第六届省赛

    题目链接:http://acm.fzu.edu.cn/problem.php?pid=2214 题目大意:给你T组数据,每组有n个物品,一个背包容量B,每件有体积和价值.问你这个背包容纳的物品最大价值 ...

  2. Web Service学习笔记

    Web Service概述 Web Service的定义 W3C组织对其的定义如下,它是一个软件系统,为了支持跨网络的机器间相互操作交互而设计.Web Service服务通常被定义为一组模块化的API ...

  3. Java--创建线程及常用方法

    继承java.lang.Thread类--Thread类代表线程类  它的常用方法如下: static Thread currentThread():返回当前正在运行的线程对象的引用. static ...

  4. vmware产品

    https://my.vmware.com/cn/group/vmware/info?slug=datacenter_cloud_infrastructure/vmware_vsphere/5_5#o ...

  5. UILabel字体加粗等属性和特效

    /* Accessing the Text Attributes text  property font  property textColor  property textAlignment  pr ...

  6. UVA 657 The die is cast

      The die is cast  InterGames is a high-tech startup company that specializes in developing technolo ...

  7. table 的thead th 固定 tbody滚动例子

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  8. Unity3D跨平台时partial分部方法的使用

    最近看到项目中插件的一部分逻辑,发现问题多多,可读性很差,并且容易出错,于是随手整理了下逻 辑.Unity3D的插件逻辑,因为要考虑到针对各平台的移植,因此会大片的出现#if/#endif等条件编译, ...

  9. UVA - 10239 The Book-shelver&#39;s Problem

    Description Problem D The Book-shelver's Problem Input: standard input Output: standard output Time ...

  10. 【转】cocos2d-x中锚点设置及定位方式

    http://blog.csdn.net/wayne5ning/article/details/8160506 说在前面:以下是基于cocos2d-2.0-x-2.0.3作的总结 问题 在cocos2 ...