国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Python中的異步編程:Asyncio

開發 后端
如果你已經決定要理解 Python 的異步部分,歡迎來到我們的“Asyncio How-to ”。哪怕連異動范式的存在都不知道的情況下,你也可以成功地使用 Python。但是,如果你對底層運行模式感興趣的話,asyncio 絕對值得查看。

如果你已經決定要理解 Python 的異步部分,歡迎來到我們的“Asyncio How-to ”。

注:哪怕連異動范式的存在都不知道的情況下,你也可以成功地使用 Python。但是,如果你對底層運行模式感興趣的話,asyncio 絕對值得查看。

異步是怎么一回事?

在傳統的順序編程中, 所有發送給解釋器的指令會一條條被執行。此類代碼的輸出容易顯現和預測。 但是…

譬如說你有一個腳本向3個不同服務器請求數據。 有時,誰知什么原因,發送給其中一個服務器的請求可能意外地執行了很長時間。想象一下從第二個服務器獲取數據用了10秒鐘。在你等待的時候,整個腳本實際上什么也沒干。如果你可以寫一個腳本可以不去等待第二個請求而是僅僅跳過它,然后開始執行第三個請求,然后回到第二個請求,執行之前離開的位置會怎么樣呢。就是這樣。你通過切換任務最小化了空轉時間。盡管如此,當你需要一個幾乎沒有I/O的簡單腳本時,你不想用異步代碼。

還有一件重要的事情要提,所有代碼在一個線程中運行。所以如果你想讓程序的一部分在后臺執行同時干一些其他事情,那是不可能的。

準備開始

這是 asyncio 主概念最基本的定義:

  • 協程 — 消費數據的生成器,但是不生成數據。Python 2.5 介紹了一種新的語法讓發送數據到生成器成為可能。我推薦查閱David Beazley “A Curious Course on Coroutines and Concurrency” 關于協程的詳細介紹。
  • 任務 — 協程調度器。如果你觀察下面的代碼,你會發現它只是讓 event_loop 盡快調用它的_step ,同時 _step 只是調用協程的下一步。
  1. class Task(futures.Future):   
  2.  
  3.     def __init__(self, coro, loop=None): 
  4.  
  5.         super().__init__(loop=loop) 
  6.  
  7.         ... 
  8.  
  9.         self._loop.call_soon(self._step) 
  10.  
  11.   
  12.  
  13.     def _step(self): 
  14.  
  15.             ... 
  16.  
  17.         try: 
  18.  
  19.             ... 
  20.  
  21.             result = next(self._coro) 
  22.  
  23.         except StopIteration as exc: 
  24.  
  25.             self.set_result(exc.value) 
  26.  
  27.         except BaseException as exc: 
  28.  
  29.             self.set_exception(exc) 
  30.  
  31.             raise 
  32.  
  33.         else
  34.  
  35.             ... 
  36.  
  37.             self._loop.call_soon(self._step)  
  • 事件循環 — 把它想成 asyncio 的中心執行器。

現在我們看一下所有這些如何融為一體。正如我之前提到的,異步代碼在一個線程中運行。

從上圖可知:

1.消息循環是在線程中執行

2.從隊列中取得任務

3.每個任務在協程中執行下一步動作

4.如果在一個協程中調用另一個協程(await <coroutine_name>),會觸發上下文切換,掛起當前協程,并保存現場環境(變量,狀態),然后載入被調用協程

5.如果協程的執行到阻塞部分(阻塞I/O,Sleep),當前協程會掛起,并將控制權返回到線程的消息循環中,然后消息循環繼續從隊列中執行下一個任務...以此類推

6.隊列中的所有任務執行完畢后,消息循環返回***個任務

異步和同步的代碼對比

現在我們實際驗證異步模式的切實有效,我會比較兩段 python 腳本,這兩個腳本除了sleep 方法外,其余部分完全相同。在***個腳本里,我會用標準的 time.sleep 方法,在第二個腳本里使用 asyncio.sleep 的異步方法。

這里使用 Sleep 是因為它是一個用來展示異步方法如何操作 I/O 的最簡單辦法。

使用同步 sleep 方法的代碼:

  1. import asyncio   
  2.  
  3. import time   
  4.  
  5. from datetime import datetime 
  6.  
  7.   
  8.  
  9.   
  10.  
  11. async def custom_sleep():   
  12.  
  13.     print('SLEEP', datetime.now()) 
  14.  
  15.     time.sleep(1) 
  16.  
  17.   
  18.  
  19. async def factorial(name, number):   
  20.  
  21.     f = 1 
  22.  
  23.     for i in range(2, number+1): 
  24.  
  25.         print('Task {}: Compute factorial({})'.format(name, i)) 
  26.  
  27.         await custom_sleep() 
  28.  
  29.         f *= i 
  30.  
  31.     print('Task {}: factorial({}) is {}\n'.format(name, number, f)) 
  32.  
  33.   
  34.  
  35.   
  36.  
  37. start = time.time()   
  38.  
  39. loop = asyncio.get_event_loop() 
  40.  
  41.   
  42.  
  43. tasks = [   
  44.  
  45.     asyncio.ensure_future(factorial("A", 3)), 
  46.  
  47.     asyncio.ensure_future(factorial("B", 4)), 
  48.  
  49.  
  50. loop.run_until_complete(asyncio.wait(tasks))   
  51.  
  52. loop.close() 
  53.  
  54.   
  55.  
  56. end = time.time()   
  57.  
  58. print("Total time: {}".format(end - start))  

腳本輸出:

  1. Task A: Compute factorial(2)   
  2.  
  3. SLEEP 2017-04-06 13:39:56.207479   
  4.  
  5. Task A: Compute factorial(3)   
  6.  
  7. SLEEP 2017-04-06 13:39:57.210128   
  8.  
  9. Task A: factorial(3) is 6 
  10.  
  11.   
  12.  
  13. Task B: Compute factorial(2)   
  14.  
  15. SLEEP 2017-04-06 13:39:58.210778   
  16.  
  17. Task B: Compute factorial(3)   
  18.  
  19. SLEEP 2017-04-06 13:39:59.212510   
  20.  
  21. Task B: Compute factorial(4)   
  22.  
  23. SLEEP 2017-04-06 13:40:00.217308   
  24.  
  25. Task B: factorial(4) is 24 
  26.  
  27.   
  28.  
  29. Total time: 5.016386032104492  

使用異步 Sleep 的代碼:

  1. import asyncio   
  2.  
  3. import time   
  4.  
  5. from datetime import datetime 
  6.  
  7.   
  8.  
  9.   
  10.  
  11. async def custom_sleep():   
  12.  
  13.     print('SLEEP {}\n'.format(datetime.now())) 
  14.  
  15.     await asyncio.sleep(1) 
  16.  
  17.   
  18.  
  19. async def factorial(name, number):   
  20.  
  21.     f = 1 
  22.  
  23.     for i in range(2, number+1): 
  24.  
  25.         print('Task {}: Compute factorial({})'.format(name, i)) 
  26.  
  27.         await custom_sleep() 
  28.  
  29.         f *= i 
  30.  
  31.     print('Task {}: factorial({}) is {}\n'.format(name, number, f)) 
  32.  
  33.   
  34.  
  35.   
  36.  
  37. start = time.time()   
  38.  
  39. loop = asyncio.get_event_loop() 
  40.  
  41.   
  42.  
  43. tasks = [   
  44.  
  45.     asyncio.ensure_future(factorial("A", 3)), 
  46.  
  47.     asyncio.ensure_future(factorial("B", 4)), 
  48.  
  49.  
  50. loop.run_until_complete(asyncio.wait(tasks))   
  51.  
  52. loop.close() 
  53.  
  54.   
  55.  
  56. end = time.time()   
  57.  
  58. print("Total time: {}".format(end - start))  

腳本輸出:

  1. Task A: Compute factorial(2)   
  2.  
  3. SLEEP 2017-04-06 13:44:40.648665 
  4.  
  5.   
  6.  
  7. Task B: Compute factorial(2)   
  8.  
  9. SLEEP 2017-04-06 13:44:40.648859 
  10.  
  11.   
  12.  
  13. Task A: Compute factorial(3)   
  14.  
  15. SLEEP 2017-04-06 13:44:41.649564 
  16.  
  17.   
  18.  
  19. Task B: Compute factorial(3)   
  20.  
  21. SLEEP 2017-04-06 13:44:41.649943 
  22.  
  23.   
  24.  
  25. Task A: factorial(3) is 6 
  26.  
  27.   
  28.  
  29. Task B: Compute factorial(4)   
  30.  
  31. SLEEP 2017-04-06 13:44:42.651755 
  32.  
  33.   
  34.  
  35. Task B: factorial(4) is 24 
  36.  
  37.   
  38.  
  39. Total time: 3.008226156234741  

從輸出可以看到,異步模式的代碼執行速度快了大概兩秒。當使用異步模式的時候(每次調用 await asyncio.sleep(1) ),進程控制權會返回到主程序的消息循環里,并開始運行隊列的其他任務(任務A或者任務B)。

當使用標準的 sleep方法時,當前線程會掛起等待。什么也不會做。實際上,標準的 sleep 過程中,當前線程也會返回一個 python 的解釋器,可以操作現有的其他線程,但這是另一個話題了。

推薦使用異步模式編程的幾個理由

很多公司的產品都廣泛的使用了異步模式,如 Facebook 旗下著名的 React Native 和 RocksDB 。像 Twitter 每天可以承載 50 億的用戶訪問,靠的也是異步模式編程。所以說,通過代碼重構,或者改變模式方法,就能讓系統工作的更快,為什么不去試一下呢? 

責任編輯:龐桂玉 來源: Python開發者
相關推薦

2017-05-05 08:44:24

PythonAsyncio異步編程

2025-10-31 12:00:00

Python并發編程開發

2011-02-22 08:49:16

.NET同步異步

2011-02-22 09:09:21

.NETAsync CTP異步

2020-02-21 08:00:00

Pythonasyncio編程語言

2023-07-14 15:10:17

PythonAsyncIO庫

2025-06-03 08:27:58

Python異步IO編程

2018-10-08 15:35:56

Python異步IO

2023-11-29 07:10:50

python協程異步編程

2011-02-24 12:53:51

.NET異步傳統

2024-12-23 08:00:45

2013-04-01 15:38:54

異步編程異步編程模型

2013-04-01 15:25:41

異步編程異步EMP

2023-08-30 08:43:42

asyncioaiohttp

2024-04-18 08:20:27

Java 8編程工具

2020-10-15 13:29:57

javascript

2021-12-10 07:47:30

Javascript異步編程

2021-08-02 11:13:28

人工智能機器學習技術

2025-12-09 06:05:00

2023-08-01 08:43:29

Python多線程
點贊
收藏

51CTO技術棧公眾號

国产精品69久久久| 国产精品亚洲四区在线观看| 亚洲三级性片| 国产中文字幕在线| 国产精品第2页| 色综合网站在线| 欧美日本中文| 麻豆tv免费在线观看| 国产精品久久久对白| 欧美日韩精品高清| 免费看的黄色欧美网站| 黄网站在线播放| 神马欧美一区二区| 欧美一区二区成人6969| 韩国女主播成人在线观看| 亚洲日本va| 色综合久久久久综合一本到桃花网| 国产资源在线免费观看| 亚洲女同精品视频| 91视频com| 日韩免费高清视频网站| 国产树林野战在线播放| 日韩av在线网址| 久久99精品国产91久久来源| 日本一本在线免费福利| 国产欧美日韩综合一区在线观看| 日韩午夜av电影| 岛国精品一区| 中国国产一级毛片| 自拍偷拍免费精品| 亚洲视频一二区| 新67194成人永久网站| 欧美少妇激情| 蜜桃成人在线视频| 精品国产一区二区三区麻豆免费观看完整版 | 国产视频一区三区| 99色在线视频| 日本精品视频在线播放| 2020国产精品| 韩国三级成人在线| 人人澡人人爽人人揉| 久久久精品电影| 国产日本亚洲高清| 无人区乱码一区二区三区| 免费男女羞羞的视频网站中文字幕| 亚洲国产精品成人av| 韩国一区二区在线观看| 黄色三级电影网| 欧美日韩成人在线播放| 亚洲国产专区校园欧美| 蜜桃网站成人| 欧美性猛交xxxx富婆弯腰| 精品一二三四区| 青青草国产成人a∨下载安卓| 黄色美女视频在线观看| 97超级碰碰人国产在线观看| 久久久蜜桃精品| 九九热这里有精品| 欧美日韩国产一级| 色婷婷一区二区三区| 日本按摩中出| 日韩一本精品| 久色乳综合思思在线视频| 一区二区三区欧美在线观看| 国产欧美日韩免费观看| 69久久夜色| 黄色一级大片免费| 97热在线精品视频在线观看| 亚洲欧美日韩精品久久久久| 亚洲免费二区| 国产精品迅雷| 波多野吉衣av| 欧美h视频在线观看| 青青草成人在线| 欧美成人vr18sexvr| 中文字幕国产一区二区| 中文字幕免费精品| 伊人www22综合色| 91高清在线| 六月丁香激情网| 久久久伊人日本| 欧美日本一区二区在线观看| 日本免费新一区视频| 伊人久久大香伊蕉在人线观看热v| 欧美极品日韩| 欧美日本精品一区二区三区| 本田岬高潮一区二区三区| 免费成人在线视频观看| 久久综合久久久久88| 97se狠狠狠综合亚洲狠狠| 亚洲精品粉嫩美女一区| 僵尸世界大战2 在线播放| 精品午夜一区二区三区在线观看| 久热国产在线| 亚洲色图自拍| 久久精品成人一区二区三区| 2024短剧网剧在线观看| 99久久国产综合精品五月天喷水| 91影院未满十八岁禁止入内| 蜜臀久久99精品久久久久久宅男| 91麻豆精品国产91久久久久| 天天影视涩香欲综合网 | 999一区二区三区| 亚洲在线第一页| 国产精品99久久久久久人| 久久久久国色av免费观看性色| 日韩精品中文字幕有码专区| 这里只有精品免费| 欧美一区二区三区四区视频| 欧美色图第一页| 欧美日韩成人综合在线一区二区| 欧美色道久久88综合亚洲精品| 亚洲成人在线观看视频| 尤物在线观看一区| 一区二区在线电影| 精品国产福利视频| 久久精品免视看| 极品美女销魂一区二区三区| 日本在线不卡视频一二三区| 国产精品一区二区美女视频免费看| 亚洲黄色成人久久久| 国产精品美女av| 91成人福利在线| 日韩第一页在线观看| 超碰在线97国产| 久久免费国产视频| 欧美日韩国产综合视频在线观看| 国产乱理伦片在线观看夜一区| www.国产亚洲| 日韩av手机在线| 日韩av在线网页| 亚洲三级在线免费观看| 林ゆな中文字幕一区二区| 国产精品xxxav免费视频| 99国产精品免费视频观看| 91成人看片| 一区二区国产精品| 美国十次了思思久久精品导航| 性色一区二区| 国产亚洲成年网址在线观看| 一区二区三区四区亚洲| 欧美精品在线观看一区二区| 亚洲精品中文字| 97国产精品久久| 久久久久久亚洲精品不卡4k岛国| 久久国产精品视频在线观看| 无夜福利视频观看| 在线观看爽视频| 欧美精品一线| 国产精品毛片无遮挡高清| 欧美三级欧美一级| 午夜精品一区二区三区在线| 成人免费淫片aa视频免费| 四虎影视永久免费在线观看一区二区三区| 三级三级久久三级久久18| 美日韩免费视频| 精品无码国产一区二区三区av| 色老板在线观看| wwwxxx黄色片| 国产一区视频免费观看| 亚洲成人观看| 99久久99九九99九九九| 中文字幕一区二区日韩精品绯色| 电影午夜精品一区二区三区| 91精品秘密在线观看| 亚洲91网站| 色天使综合视频| 国产精品一区二区久久| 在线国产精品视频| 日韩精品中文字幕一区| 日韩欧美中文免费| 国产日韩精品一区二区浪潮av | 亚洲第一二三四区| 欧美日本一区| 最新国产精品久久精品| 国产一区二区欧美日韩| 亚洲精品不卡| a级毛片免费观看在线| 久久国产精品亚洲人一区二区三区| 精品一区二区三区免费观看| 欧美日韩中文字幕日韩欧美| 7777精品视频| 在线视频2区| 91高清一区| 色狠狠色狠狠综合| 国内精品久久国产| 在线资源av| 欧美国产一级| 香蕉久久一区二区不卡无毒影院| 午夜精品一区二区三区在线视频 | 在线观看的毛片| 亚洲v.com| av不卡一区二区| 亚洲一区黄色| 在线欧美日韩精品| 韩国成人av| 国产免费av国片精品草莓男男| 欧美v国产在线一区二区三区| 大陆极品少妇内射aaaaa| 国产尤物av一区二区三区|