一 greenlet模块

不敢是yield,还是greenlet都没有实现检测io,实现遇到io切换效果

如果我们在单个线程内有20个任务,要想实现在多个任务之间切换,使用yield生成器的方式过于麻烦(需要先得到初始化一次的生成器,然后再调用send。。。非常麻烦),而使用greenlet模块可以非常简单地实现这20个任务直接的切换

安装greenlet模块

pip3 install greenlet

switch() 启动

#安装:pip3 install greenlet

from greenlet import greenlet

def eat(name):
print("%s:eat 1" %name)
g2.switch("mike")
print("%s:eat 2" %name)
g2.switch() def play(name):
print("%s:play 1" % name)
g1.switch()
print("%s:play 2" % name) g1 = greenlet(eat)
g2 = greenlet(play) g1.switch("mike") #可以在第一次switch时传入参数,以后都不需要 '''
mike:eat 1
mike:play 1
mike:eat 2
mike:play 2
'''

greenlet只是提供了一种比generator更加便捷的切换方式,当切到一个任务执行时如果遇到io,那就原地阻塞,仍然是没有解决遇到IO自动切换来提升效率的问题。

单线程里的这20个任务的代码通常会既有计算操作又有阻塞操作,我们完全可以在执行任务1时遇到阻塞,就利用阻塞的时间去执行任务2,如此,才能提高效率,这就用到了Gevent模块。

最新文章

  1. Linux nm命令
  2. iOS开发如何学习前端
  3. Visual Studio Profiler 跟踪检查每个exe dll 性能 执行时间 CPU占用情况的方法
  4. cocos2d制作动态光晕效果基础——blendFunc
  5. 大数据笔记02:大数据之Hadoop的生态系统和版本
  6. Ubuntu14.04安装PHP5
  7. nfs安装配置
  8. (转)ManyToMany注解
  9. [转载] Redis-benchmark使用总结
  10. 支持各种特殊字符的 CSV 解析类 (.net 实现)(C#读写CSV文件)
  11. Oracle问题之ORA-12560TNS:协议适配器错误
  12. python常见模块之time,datetime模块
  13. java垃圾回收GC
  14. Windows Server Backup(2016) 备份
  15. 关于mybatis中传入一个List,字符串数组,或者Map集合作为查询条件的参数
  16. java读取excel文件的代码
  17. 【转】 pthread设置线程的调度策略和优先级
  18. 基于Spring-Cloud的微服务框架设计
  19. Ubuntu 16.04安装sogou 拼音输入法
  20. Metaspace 之一:Metaspace整体介绍(永久代被替换原因、元空间特点、元空间内存查看分析方法)

热门文章

  1. yum安装nginx,配置资源访问出现403Forbidden问题
  2. 阿里云服务器(Linux)上打开新端口
  3. c++11:lambda表达式的使用
  4. Ubuntu下搜狗输入法乱码
  5. Clojure的引用类型:var,ref,agent和atom
  6. HDU 5818 Joint Stacks (优先队列)
  7. 关于JDK8对List的分组汇总
  8. linux 系统的 cache 过大,解决方案
  9. 一起学vue指令之v-bind
  10. C++抽象类实践