Python使用monkey.patch_all()解決協(xié)程阻塞問題
直接參考以下實例,采用協(xié)程訪問三個網(wǎng)站
由于IO操作非常耗時,程序經(jīng)常會處于等待狀態(tài)
比如請求多個網(wǎng)頁有時候需要等待,gevent可以自動切換協(xié)程
遇到阻塞自動切換協(xié)程,程序啟動時執(zhí)行monkey.patch_all()解決
# 由于IO操作非常耗時,程序經(jīng)常會處于等待狀態(tài)
# 比如請求多個網(wǎng)頁有時候需要等待,gevent可以自動切換協(xié)程
# 遇到阻塞自動切換協(xié)程,程序啟動時執(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ù),并且啟動運行
gevent.joinall(greenlets)
# 查看運行結(jié)果可以發(fā)現(xiàn),三個協(xié)程是同時觸發(fā)的,但是結(jié)束順序不同
# 網(wǎng)頁請求的時間不同,故結(jié)束順序不同
# 但是該程序其實只有一個線程
輸出結(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
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
PyCharm添加Anaconda中的虛擬環(huán)境Python解釋器出現(xiàn)Conda?executable?is?not
這篇文章主要給大家介紹了關(guān)于PyCharm添加Anaconda中的虛擬環(huán)境Python解釋器出現(xiàn)Conda?executable?is?not?found錯誤的解決辦法,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2023-02-02
用Python監(jiān)控NASA TV直播畫面的實現(xiàn)步驟
本文分享一個名為"Spacestills"的開源程序,它可以用于查看 NASA TV 的直播畫面(靜止幀)2021-05-05
python神經(jīng)網(wǎng)絡(luò)學習數(shù)據(jù)增強及預(yù)處理示例詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)學習數(shù)據(jù)增強及預(yù)處理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05

