这篇文章主要为大家展示了Python使用monkey.patch_all()怎么解决协程阻塞问题,内容简而易懂,希望大家可以学习一下,学习完之后肯定会有收获的,下面让小编带大家一起来看看吧。
直接参考以下实例,采用协程访问三个网站
由于IO操作非常耗时,程序经常会处于等待状态
比如请求多个网页有时候需要等待,gevent可以自动切换协程
遇到阻塞自动切换协程,程序启动时执行monkey.patch_all()解决
# 由于IO操作非常耗时,程序经常会处于等待状态 # 比如请求多个网页有时候需要等待,gevent可以自动切换协程 # 遇到阻塞自动切换协程,程序启动时执行monkey.patch_all()解决 # 首行添加下面的语句即可 from gevent import monkey; monkey.patch_all() import gevent from urllib import request def run_task(url): print("Visit --> %s" % url) try: response = request.urlopen(url) data = response.read() print("%d bytes received from %s." %(len(data), url)) except Exception: print("error") if __name__ == '__main__': urls = ['https://github.com/', 'https://blog.csdn.net/', 'https://bbs.csdn.net/'] # 定义协程方法 greenlets = [gevent.spawn(run_task, url) for url in urls] # 添加协程任务,并且启动运行 gevent.joinall(greenlets) # 查看运行结果可以发现,三个协程是同时触发的,但是结束顺序不同 # 网页请求的时间不同,故结束顺序不同 # 但是该程序其实只有一个线程
输出结果
Visit --> https://github.com/
Visit --> https://blog.csdn.net/
Visit --> https://bbs.csdn.net/
bytes received from https://blog.csdn.net/.
bytes received from https://bbs.csdn.net/.
bytes received from https://github.com/.Process finished with exit code 0
以上就是关于Python使用monkey.patch_all()怎么解决协程阻塞问题的内容,如果你们有学习到知识或者技能,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。