背景
本文主要給大家介紹了關于在Python一段程序中使用多次事件循環的相關內容,我們在Python異步程序編寫中經常要用到如下的結構
1
2
3
4
5
6
7
8
|
import asyncio async def doAsync(): await asyncio.sleep( 0 ) #... if __name__ = = "__main__" : loop = asyncio.get_event_loop() loop.run_until_complete(doAsync()) loop.close() |
這當然是很不錯的,但當你第二次使用loop的時候程序就會拋出異常RuntimeError: Event loop is closed
,這也無可厚非,理想的程序也應該是在一個時間循環中解決掉各種異步IO的問題。
但放在終端環境如Ipython中,如果想要練習Python的異步程序的編寫的話每次都要重新開啟終端未免太過于麻煩,這時候要探尋有沒有更好的解決方案。
解決方案
我們可以使用asyncio.new_event_loop
函數建立一個新的事件循環,并使用asyncio.set_event_loop
設置全局的事件循環,這時候就可以多次運行異步的事件循環了,不過最好保存默認的asyncio.get_event_loop
并在事件循環結束的時候還原回去。
最終我們的代碼就像這樣。
代碼
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
import asyncio async def doAsync(): await asyncio.sleep( 0 ) #... def runEventLoop() loop = asyncio.new_event_loop() asyncio.set_event_loop(loop) loop.run_until_complete(doAsync()) loop.close() if __name__ = = "__main__" : oldloop = asyncio.get_event_loop() runEventLoop() runEventLoop() asyncio.set_event_loop(oldloop) |
感想
事件循環本來就是要一起做很多事情,在正式的Python代碼中還是只用一個默認的事件循環比較好,平時的學習練習的話倒是隨意了。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。
原文鏈接:https://segmentfault.com/a/1190000011013476