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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(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錯誤的解決辦法,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-02-02用Python監(jiān)控NASA TV直播畫面的實現(xiàn)步驟
本文分享一個名為"Spacestills"的開源程序,它可以用于查看 NASA TV 的直播畫面(靜止幀)2021-05-05python學(xué)生管理系統(tǒng)的實現(xiàn)
這篇文章主要為大家詳細(xì)介紹了python學(xué)生管理系統(tǒng)的實現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-04-04python神經(jīng)網(wǎng)絡(luò)學(xué)習(xí)數(shù)據(jù)增強及預(yù)處理示例詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)學(xué)習(xí)數(shù)據(jù)增強及預(yù)處理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05