python?中的?asyncio?異步協(xié)程
一、定義協(xié)程
- asyncio 執(zhí)行的任務(wù),稱為協(xié)程,但是Asyncio 并不能帶來真正的并行
- Python 的多線程因為 GIL(全局解釋器鎖)的存在,也不能帶來真正的并行
import asyncio
# 通過 async 定義一個協(xié)程
async def task():
print('這是一個協(xié)程')
# 判斷是否是一個協(xié)程,返回True
print(asyncio.iscoroutinefunction(task))二、運行協(xié)程
import asyncio
# 通過 async 定義一個協(xié)程
async def task(s):
print('請等待 {} 秒'.format(s))
await asyncio.sleep(s)
print('協(xié)程結(jié)束')
# 協(xié)程運行
loop = asyncio.get_event_loop()
loop.run_until_complete(task(3))三、協(xié)程回調(diào)
- 加入我們處理完協(xié)程任務(wù)后,需要告訴開發(fā)人員,這里程序結(jié)束了
- 就需要使用到協(xié)程回調(diào)
import asyncio
# 通過 async 定義一個協(xié)程
async def task(s):
print('請等待 {} 秒'.format(s))
await asyncio.sleep(s)
return '這里task結(jié)束了,其他的繼續(xù)吧'
def callback(future):
print(future.result())
future = asyncio.ensure_future(task(3))
future.add_done_callback(callback)
loop = asyncio.get_event_loop()
loop.run_until_complete(future)
# 結(jié)果如下:
# 請等待 3 秒
# 這里task結(jié)束了,其他的繼續(xù)吧四、運行多個協(xié)程
- 常常同一個項目中有多個協(xié)程
- 需要借助
asyncio.gather函數(shù)運行
import asyncio
# 通過 async 定義一個協(xié)程
async def task1(s):
print('請等待 {} 秒'.format(s))
await asyncio.sleep(s)
print('這里task1結(jié)束了')
# 通過 async 定義一個協(xié)程
async def task2(s):
print('請等待 {} 秒'.format(s))
await asyncio.sleep(s)
print('這里task2結(jié)束了')
# 運行方法一
loop = asyncio.get_event_loop()
loop.run_until_complete(asyncio.gather(task1(1), task2(3)))
# 運行方法二
coros = [task1(1), task1(3)]
loop.run_until_complete(asyncio.gather(*coros))
# 結(jié)果如下:
# 請等待 1 秒
# 請等待 3 秒
# 這里task1結(jié)束了
# 這里task2結(jié)束了五、run_forever
- 通過
run_until_complete運行協(xié)程,協(xié)程運行完,程序也就結(jié)束退出了 - 使用
run_forever運行,程序并不會退出,除非調(diào)用loop.stop()
import asyncio # 通過 async 定義一個協(xié)程 async def task(s): await asyncio.sleep(s) # 程序并未退出結(jié)束 loop = asyncio.get_event_loop() asyncio.ensure_future(task(3)) loop.run_forever()
- 如果想讓其退出,需要調(diào)用
loop.stop() - 我們可以在協(xié)程中調(diào)用
import asyncio # 通過 async 定義一個協(xié)程 async def task(loop, s): await asyncio.sleep(s) # 關(guān)閉run_forever loop.close() loop = asyncio.get_event_loop() asyncio.ensure_future(task(loop, 3)) loop.run_forever()
六、多協(xié)程中關(guān)閉run_forever
- 單個協(xié)程中可以通過在協(xié)程中關(guān)閉,但是如果是兩個以上的協(xié)程的時候
- 如果有一個協(xié)程先做完了就stop了,將會導(dǎo)致其他的協(xié)程也會異常退出,這肯定是不允許的
- 所以我們可以在回調(diào)函數(shù)中進行關(guān)閉
import asyncio, functools
async def task(x):
await asyncio.sleep(x)
print('這是協(xié)程任務(wù)')
def callback(loop):
loop.stop()
loop = asyncio.get_event_loop()
future = asyncio.gather(task(1), task(3))
future.add_done_callback(functools.partial(callback, loop))
loop.run_forever()到此這篇關(guān)于python 中的 asyncio 異步協(xié)程 IO 教程的文章就介紹到這了,更多相關(guān)python 異步協(xié)程 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
TensorFlow高效讀取數(shù)據(jù)的方法示例
這篇文章主要介紹了TensorFlow高效讀取數(shù)據(jù)的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-02
Python發(fā)布 Web應(yīng)用的常見方法及詳細步驟
本文詳細介紹了Python發(fā)布Web應(yīng)用的常見方法,包括本地開發(fā)、Nginx+Gunicorn部署、Heroku一鍵部署、Docker容器化部署和Serverless部署,并提供了每種方法的詳細步驟和優(yōu)缺點對比,需要的朋友可以參考下2025-03-03
python中Tkinter復(fù)選框Checkbutton是否被選中判斷
這篇文章主要介紹了python中Tkinter復(fù)選框Checkbutton是否被選中判斷方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01
Python中Matplotlib圖像添加標簽的方法實現(xiàn)
本文主要介紹了Python中Matplotlib圖像添加標簽的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
pycharm打包py項目為.exe可執(zhí)行文件的兩種方式
本文主要介紹了pycharm打包py項目為.exe可執(zhí)行文件的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01
Python?matplotlib數(shù)據(jù)可視化圖繪制
這篇文章主要介紹了Python?matplotlib數(shù)據(jù)可視化圖繪制,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-07-07
用python生成(動態(tài)彩色)二維碼的方法(使用myqr庫實現(xiàn))
今天小編就為大家分享一篇用python生成(動態(tài)彩色)二維碼的方法(使用myqr庫實現(xiàn)),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06
Python 中的Schema數(shù)據(jù)結(jié)構(gòu)及類型校驗詳解
schema?是一個簡單而強大的庫,用于定義和驗證 Python 數(shù)據(jù)結(jié)構(gòu)的約束,使用?schema?庫來執(zhí)行數(shù)據(jù)結(jié)構(gòu)的校驗,本文給大家介紹Python 中的Schema數(shù)據(jù)結(jié)構(gòu)及類型校驗,感興趣的朋友一起看看吧2023-11-11

