Python多線程通信queue隊(duì)列用法實(shí)例分析
本文實(shí)例講述了Python多線程通信queue隊(duì)列用法。分享給大家供大家參考,具體如下:
queue: 什么是隊(duì)列:是一種特殊的結(jié)構(gòu),類似于列表。不過(guò)就像排隊(duì)一樣,隊(duì)列中的元素一旦取出,那么就會(huì)從隊(duì)列中刪除。 線程之間的通信可以使用隊(duì)列queue來(lái)進(jìn)行 線程如何使用queue.Queue【還有其他類型的對(duì)象下面講】來(lái)通信: 1.創(chuàng)建一個(gè)Queue對(duì)象:對(duì)象=queue.Queue(x),x是隊(duì)列容量,x可以不填,默認(rèn)沒(méi)有容量限制, 2.get()可以使線程從隊(duì)列中獲取一個(gè)元素,如果隊(duì)列為空,get會(huì)等待,get可以設(shè)置timeout參數(shù),這是等待時(shí)間 3.put()可以往隊(duì)列中放入一個(gè)元素【默認(rèn)隊(duì)列Queue是先入先出的,先放入的元素會(huì)先取出去】,如果隊(duì)列滿了,put會(huì)等待,put可以設(shè)置timeout參數(shù),這是等待時(shí)間
【下例為:sender線程發(fā)送直徑給recvder線程,recvder計(jì)算得出周長(zhǎng)】
import threading,time,queue,randomdef sender():#sender發(fā)送直徑 while True: x=random.randint(1,10) print('send done:',x) q.put(x)#每個(gè)一秒就放入一個(gè)隨機(jī)數(shù) time.sleep(1)#每隔一秒就放入一個(gè)adef recvder():#recvder計(jì)算周長(zhǎng) while True: x=q.get() print('recv done:',x*3.14)#每隔一秒就取出一個(gè)元素,計(jì)算結(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 對(duì)象已經(jīng)包含了必要的鎖,所以不用擔(dān)心會(huì)出錯(cuò)
import threading,time,queue,randomdef sender():#sender發(fā)送直徑 while True: x=random.randint(1,10) print('send done:',x) q.put(x)#每個(gè)一秒就放入一個(gè)隨機(jī)數(shù) time.sleep(1)#每隔一秒就放入一個(gè)adef recvder():#recvder計(jì)算周長(zhǎng) while True: x=q.get() print(threading.current_thread(),'recv done:',x*3.14)#每隔一秒就取出一個(gè)元素,計(jì)算結(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()
注:
隊(duì)列可以有容量限制:

timeout的設(shè)置:

import threading,queue,time'''這個(gè)例子是:廠家跟司機(jī)約定,生產(chǎn)滿3個(gè),司機(jī)才來(lái)拉,而一個(gè)個(gè)拉走,只有當(dāng)3個(gè)都拉走,廠家才繼續(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)#用來(lái)測(cè)試是否堵塞,證明不是因?yàn)樗緳C(jī)的sleep堵塞運(yùn)行def driver():#老司機(jī) 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進(jìn)程與線程操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》、《Python+MySQL數(shù)據(jù)庫(kù)程序設(shè)計(jì)入門教程》及《Python常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章:
1. php使用正則驗(yàn)證密碼字段的復(fù)雜強(qiáng)度原理詳細(xì)講解 原創(chuàng)2. vue前端RSA加密java后端解密的方法實(shí)現(xiàn)3. JSP+Servlet實(shí)現(xiàn)文件上傳到服務(wù)器功能4. 基于jsp+mysql實(shí)現(xiàn)在線水果銷售商城系統(tǒng)5. 基于javaweb+jsp實(shí)現(xiàn)企業(yè)財(cái)務(wù)記賬管理系統(tǒng)6. CSS可以做的幾個(gè)令你嘆為觀止的實(shí)例分享7. ASP動(dòng)態(tài)網(wǎng)頁(yè)制作技術(shù)經(jīng)驗(yàn)分享8. 淺談?dòng)蓀osition屬性引申的css進(jìn)階討論9. ASP中實(shí)現(xiàn)字符部位類似.NET里String對(duì)象的PadLeft和PadRight函數(shù)10. 利用CSS3新特性創(chuàng)建透明邊框三角

網(wǎng)公網(wǎng)安備