您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了Python使用monkey.patch_all()怎么解決協(xié)程阻塞問題,內(nèi)容簡而易懂,希望大家可以學(xué)習(xí)一下,學(xué)習(xí)完之后肯定會(huì)有收獲的,下面讓小編帶大家一起來看看吧。
直接參考以下實(shí)例,采用協(xié)程訪問三個(gè)網(wǎng)站
由于IO操作非常耗時(shí),程序經(jīng)常會(huì)處于等待狀態(tài)
比如請(qǐng)求多個(gè)網(wǎng)頁有時(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)頁有時(shí)候需要等待,gevent可以自動(dòng)切換協(xié)程 # 遇到阻塞自動(dòng)切換協(xié)程,程序啟動(dòng)時(shí)執(zhí)行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/'] # 定義協(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)頁請(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
以上就是關(guān)于Python使用monkey.patch_all()怎么解決協(xié)程阻塞問題的內(nèi)容,如果你們有學(xué)習(xí)到知識(shí)或者技能,可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。