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