簡單了解python協(xié)程的相關知識
什么是協(xié)程
協(xié)程是python種一種實現(xiàn)多任務的方式,他是一種比線程更加小的單元,占用更小的執(zhí)行單元(資源),為啥說他是一個執(zhí)行單元,因為他自帶CPU上下文,這樣在合適gr的時機,可以把一個協(xié)程切換到另一個協(xié)程,只要在這個過程中保存和恢復cpu上下文那么程序還是可以運行的
通俗的理解: 一個線程中的某個函數(shù),可以在任何地方保存當前函數(shù)的一些臨時變量,然后切換到另一個函數(shù)中運行,并且切換的次數(shù)以及社么時候再切換回來是可控的
協(xié)程和線程的差異
在實現(xiàn)多任務時,線程會自己歡子一些數(shù)據(jù),操作系統(tǒng)切換時需要恢復數(shù)據(jù),所以線程恢復比較耗性能
協(xié)程底層原理(舉例)
''' 1,協(xié)程的實現(xiàn)原理,底層通過 yield 實現(xiàn) ''' def work1(): #工作任務 for i in range(10): print('work1----{}'.format(i)) yield i def work2(): for i in range(10): print('work2----{}'.format(i)) yield i def work3(): for i in range(10): print('work3----{}'.format(i)) yield i g1 = work1() g2 = work2() g3 = work3() while True: #循環(huán)調(diào)用生成器實現(xiàn)任務切換 try: print(next(g1)) print(next(g2)) print(next(g3)) except StopIteration : pass break
協(xié)程 greenlet
python -m pip install greenlet
示例
''' 1,展示greenelent ,不能自動切換需要手動切換 ''' import greenlet def work1(): for i in range(10): print('work1----{}'.format(i)) g2.switch() #切換到g2 def work2(): for i in range(10): print('work2----{}'.format(i)) g1.switch() #切換到g1 g1 = greenlet.greenlet(work1) #返回協(xié)程對象 g2 = greenlet.greenlet(work2) g1.switch() #啟動開關
執(zhí)行順序
gevent
greenlet 已經(jīng)實現(xiàn)了協(xié)程,但是還是人工切換,gevent 提供了自動切換功能,其原理是執(zhí)行過程中遇到IO操作,自動切換
''' 協(xié)程gevent IO操作會切換 ''' import gevent def work1(): # 工作任務 for i in range(10): print('work1----{}'.format(i)) gevent.sleep(0.5) def work2(): for i in range(10): print('work2----{}'.format(i)) gevent.sleep(0.5) g1 = gevent.spawn(work1) #指定工作函數(shù) g2 = gevent.spawn(work2) #指定工作函數(shù) g1.join() #等待協(xié)程執(zhí)行完成再往下走 g2.join()
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
pytorch常用數(shù)據(jù)類型所占字節(jié)數(shù)對照表一覽
這篇文章主要介紹了pytorch常用數(shù)據(jù)類型所占字節(jié)數(shù)對照表一覽,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05Python基于easygui實現(xiàn)pdf和word轉換小程序
這篇文章主要為大家詳細介紹了Python如何基于easygui實現(xiàn)pdf和word轉換小程序,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下2024-04-04matplotlib之Font family [‘sans-serif‘] not&nbs
本文主要介紹了matplotlib之Font family [‘sans-serif‘] not found的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-03-03Python中axis=0與axis=1指的方向有什么不同詳解
對數(shù)據(jù)進行操作時,經(jīng)常需要在橫軸方向或者數(shù)軸方向?qū)?shù)據(jù)進行操作,這時需要設定參數(shù)axis的值,下面這篇文章主要給大家介紹了關于Python中axis=0與axis=1指的方向有什么不同的相關資料,需要的朋友可以參考下2024-01-01