亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python多線程通信queue隊(duì)列用法實(shí)例分析

 更新時(shí)間:2020年03月24日 10:57:35   作者:隨風(fēng)行云  
這篇文章主要介紹了Python多線程通信queue隊(duì)列用法,結(jié)合實(shí)例形式分析了Python多線程通信queue隊(duì)列相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了Python多線程通信queue隊(duì)列用法。分享給大家供大家參考,具體如下:

queue:

  • 什么是隊(duì)列:是一種特殊的結(jié)構(gòu),類似于列表。不過就像排隊(duì)一樣,隊(duì)列中的元素一旦取出,那么就會(huì)從隊(duì)列中刪除。
  • 線程之間的通信可以使用隊(duì)列queue來進(jìn)行
  • 線程如何使用queue.Queue【還有其他類型的對(duì)象下面講】來通信:
    • 1.創(chuàng)建一個(gè)Queue對(duì)象:對(duì)象=queue.Queue(x),x是隊(duì)列容量,x可以不填,默認(rèn)沒有容量限制,    
    • 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í)間
    • image

【下例為:sender線程發(fā)送直徑給recvder線程,recvder計(jì)算得出周長(zhǎng)】

import threading,time,queue,random
def 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è)a

def 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,random
def 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è)a

def 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ì)列可以有容量限制:

image

timeout的設(shè)置:

image


隊(duì)列的其他相關(guān)函數(shù)【設(shè)q為一個(gè)Queue對(duì)象】:

  • q.qsize():返回當(dāng)前隊(duì)列的元素個(gè)數(shù)
  • q.empty():判斷隊(duì)列是否空,返回布爾值
  • q.full():判斷隊(duì)列是否滿,返回布爾值
  • q.get_nowait():直接使用get(),如果此時(shí)隊(duì)列中沒有元素,那么會(huì)阻塞等待,使用get_nowait()后,如果隊(duì)列中沒有元素,那么會(huì)報(bào)錯(cuò)
  • q.put_nowait():直接使用put(),如果此時(shí)隊(duì)列滿了,那么會(huì)阻塞等待,使用put_nowait()后,如果隊(duì)列已經(jīng)滿了,那么會(huì)報(bào)錯(cuò)
  • q.task_done() :在完成一項(xiàng)工作之后,task_done()函數(shù)向任務(wù)已經(jīng)完成的隊(duì)列發(fā)送一個(gè)信號(hào)【功能類似于:有一個(gè)只能承重一個(gè)人的獨(dú)木橋,A來了發(fā)現(xiàn)B在橋上,所以A不能上橋,他就在等,等到B過完橋后喊一下他,他才知道B過完橋了】【q.task_done主要是跟q.join()配合使用的】
  • q.join():實(shí)際上意味著等到隊(duì)列為空,再執(zhí)行別的操作【每次get后需要調(diào)用task_done,直到所有隊(duì)列為空,這時(shí)才會(huì)執(zhí)行join下面的】
import threading,queue,time
"""
這個(gè)例子是:廠家跟司機(jī)約定,生產(chǎn)滿3個(gè),司機(jī)才來拉,
而一個(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)#用來測(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()

image


queue中除了Queue之外,還有其他的隊(duì)列,下面是常用的幾個(gè):

  • Queue是先入先出的隊(duì)列:

image

  • LifoQueue則是后入先出的隊(duì)列

image

  • PriorityQueue是由裝入元素時(shí)指定的優(yōu)先級(jí)來決定出元素的順序的:
    • 創(chuàng)建方法:隊(duì)列對(duì)象=queue.PriorityQueue()
    • 優(yōu)先級(jí)是小的優(yōu)先,但不能混合排序,str的只能跟str的一起排序,int的只能跟int一起排序
    • PriorityQueue的put的參數(shù)是元組,格式為:隊(duì)列對(duì)象.put((優(yōu)先級(jí), 數(shù)據(jù)))

imageimage

  • deque 是雙端隊(duì)列,允許先入先出和后入后出,即兩端都可以出
    • 由于雙端隊(duì)列實(shí)用性不大,實(shí)際上與列表沒什么區(qū)別,在此不做闡述,大家可以參考://chabaoo.cn/article/183382.htm

更多關(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常見數(shù)據(jù)庫(kù)操作技巧匯總

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Python可視化神器pyecharts繪制雷達(dá)圖

    Python可視化神器pyecharts繪制雷達(dá)圖

    這篇文章主要介紹了Python可視化神器pyecharts繪制雷達(dá)圖,雷達(dá)圖是以從同一點(diǎn)開始的軸上表示的三個(gè)或更多個(gè)定量變量的二維圖表的形式顯示多變量數(shù)據(jù)的圖形方法
    2022-07-07
  • MATLAB中print函數(shù)使用示例詳解

    MATLAB中print函數(shù)使用示例詳解

    print函數(shù)的功能是打印圖窗或保存為特定文件格式,這篇文章主要介紹了MATLAB中print函數(shù)使用,需要的朋友可以參考下
    2023-03-03
  • 在python中將list分段并保存為array類型的方法

    在python中將list分段并保存為array類型的方法

    今天小編就為大家分享一篇在python中將list分段并保存為array類型的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • win7安裝python生成隨機(jī)數(shù)代碼分享

    win7安裝python生成隨機(jī)數(shù)代碼分享

    python3生成隨機(jī)數(shù)代碼分享,在win7上測(cè)試通過
    2013-12-12
  • Python實(shí)現(xiàn)將xml導(dǎo)入至excel

    Python實(shí)現(xiàn)將xml導(dǎo)入至excel

    本文給大家講解的是使用Python的Testlink實(shí)現(xiàn)將實(shí)現(xiàn)將xml導(dǎo)入至excel表格中,方法非常的簡(jiǎn)單,另外附上其他小伙伴的方法,有需要的童鞋們可以參考下。
    2015-11-11
  • 如何利用Matplotlib庫(kù)繪制動(dòng)畫及保存GIF圖片

    如何利用Matplotlib庫(kù)繪制動(dòng)畫及保存GIF圖片

    這篇文章主要給大家介紹了關(guān)于如何利用Matplotlib庫(kù)繪制動(dòng)畫及保存GIF圖片的相關(guān)資料,matplotlib模塊提供了很高級(jí)和非常友好的使用方式,使用起來也是非常方便的,需要的朋友可以參考下
    2021-06-06
  • python?命令行界面的用戶交互及優(yōu)化

    python?命令行界面的用戶交互及優(yōu)化

    這篇文章主要為大家介紹了python?命令行界面的用戶交互及優(yōu)化方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • Python中re模塊的元字符使用小結(jié)

    Python中re模塊的元字符使用小結(jié)

    元字符是正則表達(dá)式中具有特殊意義的專用字符,本文主要介紹了Python中re模塊的元字符使用小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • Python進(jìn)程間通信multiprocess代碼實(shí)例

    Python進(jìn)程間通信multiprocess代碼實(shí)例

    這篇文章主要介紹了Python進(jìn)程間通信multiprocess代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Python+selenium 自動(dòng)化快手短視頻發(fā)布的實(shí)現(xiàn)過程

    Python+selenium 自動(dòng)化快手短視頻發(fā)布的實(shí)現(xiàn)過程

    這篇文章主要介紹了Python+selenium 自動(dòng)化快手短視頻發(fā)布,通過調(diào)用已啟用的瀏覽器,可以實(shí)現(xiàn)直接跳過每次的登錄過程,上傳功能的使用方法通過代碼給大家介紹的也非常詳細(xì),需要的朋友可以參考下
    2021-10-10

最新評(píng)論