您好,登錄后才能下訂單哦!
這篇文章給大家介紹怎么在Python中使用semaphore evevt實現生產者消費者模型,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
1、簡單易用,與C/C++、Java、C# 等傳統語言相比,Python對代碼格式的要求沒有那么嚴格;2、Python屬于開源的,所有人都可以看到源代碼,并且可以被移植在許多平臺上使用;3、Python面向對象,能夠支持面向過程編程,也支持面向對象編程;4、Python是一種解釋性語言,Python寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序;5、Python功能強大,擁有的模塊眾多,基本能夠實現所有的常見功能。
線程鎖相當于同時只能有一個線程申請鎖,有的場景無數據修改互斥要求可以同時讓多個線程同時運行,且需要限制并發線程數量時可以使用信號量
import threading, time, queue def test(name): semaphore.acquire() #獲取信號量鎖 print('my name is %s' %name) time.sleep(1) semaphore.release() #釋放信號量鎖 semaphore = threading.BoundedSemaphore(5) #創建一個信號量同時可以運行3個線程 for i in range(20): t = threading.Thread(target=test, args=(i,)) t.start() while threading.active_count() == 1: print("all run done")
兩個或者多個線程需要交互時,且一個進程需要根據另一線程狀態執行對應操作時,可以通過event來設置線程狀態達到期望的效果,下面是一個紅綠燈的例子
event = threading.Event() #實例化一個event def light(): while True: print("紅燈亮了,請停車") time.sleep(20) #開始是紅燈20s event.set() #紅燈時間到了,設置標志位 print("綠燈亮了,請通行") time.sleep(30) #持續30s紅燈 event.clear() #清空標志位 def car(num): while True: if event.is_set():#檢測event被設置則執行 print("car %s run"%num) time.sleep(5) else: print("this is red light waiting") event.wait() #此處會卡主,直到狀態被設置才會向下執行 Light = threading.Thread(target=light,) Light.start() for i in range(10): Car = threading.Thread(target=car, args=(i,)) Car.start()
當多個線程需要交互數據可以使用queue來進行數據傳遞,下面是經典的生產者消費者多線程模型示例,其中包含線程queue的基本使用方法
my_queue = queue.Queue() #實例化一個隊列 queue1 = queue.LifoQueue() #后進 先出隊列 queue2 = queue.PriorityQueue() #帶優先級的隊列 def pro(): for i in range(100): my_queue.put(i) #隊列里面放數據 def con(): while my_queue.qsize() > 0: #當隊列有數據時候從隊列取數據 print("i an a consumer,get num %s"%my_queue.get(timeout=3)) time.sleep(2) else: print("my queue is empty") Pro = threading.Thread(target=pro) Pro.start() for j in range(10): Con = threading.Thread(target=con) Con.start()
關于怎么在Python中使用semaphore evevt實現生產者消費者模型就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。