揭秘Python并发编程——协程
原文鏈接:https://baijiahao.baidu.com/s?id=1649450510185145678&wfr=spider&for=pc
Python并發編程一直是進階當中不可跨越的一道坎,其中包括進程、線程、協程,今天我們就來聊一聊協程。
協程的定義很簡單,從頭到尾只有一條任務線在進行,就像是你可以在煮雞蛋的時候背單詞,但無論是煮雞蛋還是背單詞,始終都是你一個人在進行任務,線程的概念稍有不同,是把一個人分成兩個人,一個在煮雞蛋,一個在背單詞,我們直接上代碼看一下:
這是一段普通的代碼,我們分別讓不同的url睡眠不同的時間,總共是10s,看一下運行結果:
然后,我們使用協程來執行這段代碼:
我們來看一下運行時間:
從結果來看,運行時間從10s縮短到了4s,基本上是最長的那個程序的運行時間。
那么具體的協程實現的具體原理是什么呢,我們來分解一下代碼:
先看一下輸出內容:
我們這里使用async來聲明一個異步函數,使用await來執行異步函數,await的執行效果會使程序阻塞在這里,最后需要使用asyncio.run()來觸發運行,asyncio.run()作為主程序的入口函數,在整個過程中只執行一次
當使用Task創建任務時,所有任務都會做好準備:
首先打印'before await'執行await task1,打印'worker_1 start',遇到sleep開始切換切換到執行await task2,后續沒有需要執行的任務,所以暫時停留在Task2當task1的sleep完成,任務切回task1,打印'worker_1 done'之后切回task2等待sleep完成,打印'worker_2 done'以上就是協程的執行順序了。
希望大家這個例子可以幫助大家更好的運用python。
總結
以上是生活随笔為你收集整理的揭秘Python并发编程——协程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 神经网络算法学习---mini-batc
- 下一篇: python杂谈