欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python中Task封裝協(xié)程的知識點(diǎn)總結(jié)

 更新時(shí)間:2021年07月21日 08:56:15   作者:小妮淺淺  
在本篇內(nèi)容里小編給大家總結(jié)的是一篇關(guān)于python中Task封裝協(xié)程的知識點(diǎn)總結(jié)內(nèi)容,有興趣的朋友們可以跟著學(xué)習(xí)下。

說明

1、Task是Future的子類,Task是對協(xié)程的封裝,我們把多個(gè)Task放在循環(huán)調(diào)度列表中,等待調(diào)度執(zhí)行。

2、Task對象可以跟蹤任務(wù)和狀態(tài)。Future(Task是Futrue的子類)為我們提供了異步編程中最終結(jié)果的處理(Task類還具有狀態(tài)處理功能)。

3、把協(xié)程封裝成Task,加入一個(gè)隊(duì)列等待調(diào)用。剛創(chuàng)建Task的時(shí)候不執(zhí)行,遇到await就執(zhí)行。

實(shí)例

import asyncio
 
async def func():
print(1)
await asyncio.sleep(2)
print(2)
return "返回值"
 
 
async def main():
print("main開始")
 
# 創(chuàng)建協(xié)程,將協(xié)程封裝到Task對象中并添加到事件循環(huán)的任務(wù)列表中,等待事件循環(huán)去執(zhí)行(默認(rèn)是就緒狀態(tài))。
# 在調(diào)用
task_list = [
asyncio.create_task(func(), name="n1"),
asyncio.create_task(func(), name="n2")
]
 
print("main結(jié)束")
 
# 當(dāng)執(zhí)行某協(xié)程遇到IO操作時(shí),會自動(dòng)化切換執(zhí)行其他任務(wù)。
# 此處的await是等待所有協(xié)程執(zhí)行完畢,并將所有協(xié)程的返回值保存到done
# 如果設(shè)置了timeout值,則意味著此處最多等待的秒,完成的協(xié)程返回值寫入到done中,未完成則寫到pending中。
done, pending = await asyncio.wait(task_list, timeout=None)
print(done, pending)
 
 
asyncio.run(main())

知識點(diǎn)擴(kuò)展:

Task 概念及用法

  • Task,是 python 中與事件循環(huán)進(jìn)行交互的一種主要方式。

創(chuàng)建 Task,意思就是把協(xié)程封裝成 Task 實(shí)例,并追蹤協(xié)程的 運(yùn)行 / 完成狀態(tài),用于未來獲取協(xié)程的結(jié)果。

  • Task 核心作用:在事件循環(huán)中添加多個(gè)并發(fā)任務(wù);

具體來說,是通過 asyncio.create_task() 創(chuàng)建 Task,讓協(xié)程對象加入時(shí)事件循環(huán)中,等待被調(diào)度執(zhí)行。

注意:Python 3.7 以后的版本支持 asyncio.create_task(),在此之前的寫法為 loop.create_task(),開發(fā)過程中需要注意代碼寫法對不同版本 python 的兼容性。

  • 需要指出的是,協(xié)程封裝為 Task 后不會立馬啟動(dòng),當(dāng)某個(gè)代碼 await 這個(gè) Task 的時(shí)候才會被執(zhí)行。

當(dāng)多個(gè) Task 被加入一個(gè) task_list 的時(shí)候,添加 Task 的過程中 Task 不會執(zhí)行,必須要用 await asyncio.wait() 或 await asyncio.gather() 將 Task 對象加入事件循環(huán)中異步執(zhí)行。

  • 一般在開發(fā)中,常用的寫法是這樣的:

-- 先創(chuàng)建 task_list 空列表;
-- 然后用 asyncio.create_task() 創(chuàng)建 Task;
-- 再把 Task 對象加入 task_list;
-- 最后使用 await asyncio.wait 或 await asyncio.gather 將 Task 對象加入事件循環(huán)中異步執(zhí)行。

注意:創(chuàng)建 Task 對象時(shí),除了可以使用 asyncio.create_task() 之外,還可以用最低層級的 loop.create_task() 或 asyncio.ensure_future(),他們都可以用來創(chuàng)建 Task 對象,其中關(guān)于 ensure_future 相關(guān)內(nèi)容本文接下來會一起講。

Task 用法代碼示例:

import asyncio
import arrow


def current_time():
    '''
    獲取當(dāng)前時(shí)間
    :return:
    '''
    cur_time = arrow.now().to('Asia/Shanghai').format('YYYY-MM-DD HH:mm:ss')
    return cur_time


async def func(sleep_time):
    func_name_suffix = sleep_time        # 使用 sleep_time(函數(shù) I/O 等待時(shí)長)作為函數(shù)名后綴,以區(qū)分任務(wù)對象
    print(f"[{current_time()}] 執(zhí)行異步函數(shù) {func.__name__}-{func_name_suffix}")
    await asyncio.sleep(sleep_time)
    print(f"[{current_time()}] 函數(shù) {func.__name__}-{func_name_suffix} 執(zhí)行完畢")
    return f"【[{current_time()}] 得到函數(shù) {func.__name__}-{func_name_suffix} 執(zhí)行結(jié)果】"


async def run():
    task_list = []
    for i in range(5):
        task = asyncio.create_task(async_func(i))
        task_list.append(task)

    done, pending = await asyncio.wait(task_list, timeout=None)
    for done_task in done:
        print((f"[{current_time()}] 得到執(zhí)行結(jié)果 {done_task.result()}"))

def main():
    loop = asyncio.get_event_loop()
    loop.run_until_complete(run())


if __name__ == '__main__':
    main()

到此這篇關(guān)于python中Task封裝協(xié)程的知識點(diǎn)總結(jié)的文章就介紹到這了,更多相關(guān)python中Task封裝協(xié)程內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)篩選及提取序列中元素的方法

    Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)篩選及提取序列中元素的方法

    這篇文章主要介紹了Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)篩選及提取序列中元素的方法,涉及Python列表推導(dǎo)式、生成器表達(dá)式及filter()函數(shù)相關(guān)使用技巧,需要的朋友可以參考下
    2018-03-03
  • pytorch中的優(yōu)化器optimizer.param_groups用法

    pytorch中的優(yōu)化器optimizer.param_groups用法

    這篇文章主要介紹了pytorch中的優(yōu)化器optimizer.param_groups用法,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python中json庫的操作指南

    Python中json庫的操作指南

    JSON是存儲和交換文本信息的語法,類似XML,JSON比XML更小、更快,更易解析,且易于人閱讀和編寫,下面這篇文章主要給大家介紹了關(guān)于Python中json庫的操作指南,需要的朋友可以參考下
    2023-04-04
  • Python+OpenCV實(shí)現(xiàn)六種常用圖像特效

    Python+OpenCV實(shí)現(xiàn)六種常用圖像特效

    這篇文章主要為大家介紹了用Python和OpenCV實(shí)現(xiàn)的六種常見圖像特效:圖像融合、灰度處理、馬賽克效果、浮雕效果、毛玻璃效果和顏色反轉(zhuǎn),需要的可以參考一下
    2022-05-05
  • Pytest+Request+Allure+Jenkins實(shí)現(xiàn)接口自動(dòng)化

    Pytest+Request+Allure+Jenkins實(shí)現(xiàn)接口自動(dòng)化

    這篇文章介紹了Pytest+Request+Allure+Jenkins實(shí)現(xiàn)接口自動(dòng)化的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • 解決pyqt5異常退出無提示信息的問題

    解決pyqt5異常退出無提示信息的問題

    這篇文章主要介紹了解決pyqt5異常退出無提示信息的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 基于Pygame中Pygame模塊的大戰(zhàn)外星人實(shí)戰(zhàn)

    基于Pygame中Pygame模塊的大戰(zhàn)外星人實(shí)戰(zhàn)

    本文主要介紹了基于Pygame中Pygame模塊的大戰(zhàn)外星人實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • 在Python中操作MongoDB的詳細(xì)教程和案例分享

    在Python中操作MongoDB的詳細(xì)教程和案例分享

    MongoDB是一個(gè)高性能、開源、無模式的文檔型數(shù)據(jù)庫,非常適合存儲JSON風(fēng)格的數(shù)據(jù),Python作為一種廣泛使用的編程語言,通過PyMongo庫可以方便地與MongoDB進(jìn)行交互,本文將詳細(xì)介紹如何在Python中使用PyMongo庫來操作MongoDB數(shù)據(jù)庫,需要的朋友可以參考下
    2024-08-08
  • 淺談Python中列表生成式和生成器的區(qū)別

    淺談Python中列表生成式和生成器的區(qū)別

    這篇文章主要介紹了淺談Python中列表生成式和生成器的區(qū)別,是Python入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-08-08
  • 淺談python中真正關(guān)閉socket的方法

    淺談python中真正關(guān)閉socket的方法

    今天小編就為大家分享一篇淺談python中真正關(guān)閉socket的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12

最新評論