Python多線程通信queue隊列用法實例分析
本文實例講述了Python多線程通信queue隊列用法。分享給大家供大家參考,具體如下:
queue: 什么是隊列:是一種特殊的結(jié)構(gòu),類似于列表。不過就像排隊一樣,隊列中的元素一旦取出,那么就會從隊列中刪除。 線程之間的通信可以使用隊列queue來進行 線程如何使用queue.Queue【還有其他類型的對象下面講】來通信: 1.創(chuàng)建一個Queue對象:對象=queue.Queue(x),x是隊列容量,x可以不填,默認沒有容量限制, 2.get()可以使線程從隊列中獲取一個元素,如果隊列為空,get會等待,get可以設置timeout參數(shù),這是等待時間 3.put()可以往隊列中放入一個元素【默認隊列Queue是先入先出的,先放入的元素會先取出去】,如果隊列滿了,put會等待,put可以設置timeout參數(shù),這是等待時間
【下例為:sender線程發(fā)送直徑給recvder線程,recvder計算得出周長】
import threading,time,queue,randomdef sender():#sender發(fā)送直徑 while True: x=random.randint(1,10) print('send done:',x) q.put(x)#每個一秒就放入一個隨機數(shù) time.sleep(1)#每隔一秒就放入一個adef recvder():#recvder計算周長 while True: x=q.get() print('recv done:',x*3.14)#每隔一秒就取出一個元素,計算結(jié)果 time.sleep(1)q=queue.Queue()t1=threading.Thread(target=sender)t2=threading.Thread(target=recvder)t1.start()t2.start()t1.join()t2.join() Queue 對象已經(jīng)包含了必要的鎖,所以不用擔心會出錯
import threading,time,queue,randomdef sender():#sender發(fā)送直徑 while True: x=random.randint(1,10) print('send done:',x) q.put(x)#每個一秒就放入一個隨機數(shù) time.sleep(1)#每隔一秒就放入一個adef recvder():#recvder計算周長 while True: x=q.get() print(threading.current_thread(),'recv done:',x*3.14)#每隔一秒就取出一個元素,計算結(jié)果 time.sleep(2)q=queue.Queue()t1=threading.Thread(target=sender)t2=threading.Thread(target=recvder)t3=threading.Thread(target=recvder)t1.start()t2.start()t3.start()t1.join()t2.join()t3.join()
注:
隊列可以有容量限制:
timeout的設置:
import threading,queue,time'''這個例子是:廠家跟司機約定,生產(chǎn)滿3個,司機才來拉,而一個個拉走,只有當3個都拉走,廠家才繼續(xù)生產(chǎn)'''def producer():#廠家 while True: for i in range(3): q.put(i) start_time=time.time() q.join()##結(jié)果顯示join這里堵塞住了廠家線程 print('wait time:',time.time()-start_time)#用來測試是否堵塞,證明不是因為司機的sleep堵塞運行def driver():#老司機 while True: for i in range(3): print(q.get()) q.task_done() print('') time.sleep(2)q=queue.Queue()t1=threading.Thread(target=producer)t2=threading.Thread(target=driver)t1.start()t2.start()t1.join()t2.join()
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python進程與線程操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》、《Python+MySQL數(shù)據(jù)庫程序設計入門教程》及《Python常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家Python程序設計有所幫助。
相關(guān)文章:
1. 使用Python和百度語音識別生成視頻字幕的實現(xiàn)2. 利用ajax+php實現(xiàn)商品價格計算3. CSS可以做的幾個令你嘆為觀止的實例分享4. 在JSP中使用formatNumber控制要顯示的小數(shù)位數(shù)方法5. xml中的空格之完全解說6. ASP刪除img標簽的style屬性只保留src的正則函數(shù)7. msxml3.dll 錯誤 800c0019 系統(tǒng)錯誤:-2146697191解決方法8. axios和ajax的區(qū)別點總結(jié)9. 怎樣才能用js生成xmldom對象,并且在firefox中也實現(xiàn)xml數(shù)據(jù)島?10. css代碼優(yōu)化的12個技巧
