亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python使用monkey.patch_all()解決協(xié)程阻塞問(wèn)題

 更新時(shí)間:2020年04月15日 08:37:21   作者:cool小伙  
這篇文章主要介紹了Python使用monkey.patch_all()解決協(xié)程阻塞問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

直接參考以下實(shí)例,采用協(xié)程訪問(wèn)三個(gè)網(wǎng)站

由于IO操作非常耗時(shí),程序經(jīng)常會(huì)處于等待狀態(tài)

比如請(qǐng)求多個(gè)網(wǎng)頁(yè)有時(shí)候需要等待,gevent可以自動(dòng)切換協(xié)程

遇到阻塞自動(dòng)切換協(xié)程,程序啟動(dòng)時(shí)執(zhí)行monkey.patch_all()解決

# 由于IO操作非常耗時(shí),程序經(jīng)常會(huì)處于等待狀態(tài)
# 比如請(qǐng)求多個(gè)網(wǎng)頁(yè)有時(shí)候需要等待,gevent可以自動(dòng)切換協(xié)程
# 遇到阻塞自動(dòng)切換協(xié)程,程序啟動(dòng)時(shí)執(zhí)行monkey.patch_all()解決
# 首行添加下面的語(yǔ)句即可
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/']
  # 定義協(xié)程方法
  greenlets = [gevent.spawn(run_task, url) for url in urls]
  # 添加協(xié)程任務(wù),并且啟動(dòng)運(yùn)行
  gevent.joinall(greenlets)

# 查看運(yùn)行結(jié)果可以發(fā)現(xiàn),三個(gè)協(xié)程是同時(shí)觸發(fā)的,但是結(jié)束順序不同
# 網(wǎng)頁(yè)請(qǐng)求的時(shí)間不同,故結(jié)束順序不同
# 但是該程序其實(shí)只有一個(gè)線程

輸出結(jié)果

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論