zoukankan      html  css  js  c++  java
  • python 并发编程 协程 greenlet模块

    一 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模块。

  • 相关阅读:
    BLOB
    cesium 检测视图改变的代码
    有关Nodejs的一些插件介绍
    线程基础知识
    进程和线程概念对比
    C#对象与XMl文件之间的相互转换(转)
    简介C#读取XML的方式(转)
    关于c# Debug和Release的区别 (转)
    c++堆和栈(转)
    浅谈C#堆栈与托管堆的工作方式(转)
  • 原文地址:https://www.cnblogs.com/mingerlcm/p/11147190.html
Copyright © 2011-2022 走看看