电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:19日期:2022-08-01 13:39:20

本文實(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í)間 Python多線程通信queue隊(duì)列用法實(shí)例分析

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

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

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

timeout的設(shè)置:

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

隊(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)#用來測試是否堵塞,證明不是因?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()

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

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

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

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

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

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ù)))

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

deque 是雙端隊(duì)列,允許先入先出和后入后出,即兩端都可以出 由于雙端隊(duì)列實(shí)用性不大,實(shí)際上與列表沒什么區(qū)別,在此不做闡述,大家可以參考://www.jb51.net/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ù)庫程序設(shè)計(jì)入門教程》及《Python常見數(shù)據(jù)庫操作技巧匯總》

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

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: sus630/303cu不锈钢棒,440C/430F/17-4ph不锈钢研磨棒-江苏德镍金属科技有限公司 | 成都装修公司-成都装修设计公司推荐-成都朗煜装饰公司 | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 安规电容|薄膜电容|陶瓷电容|智旭JEC安规电容厂家 | 抖音短视频运营_企业网站建设_网络推广_全网自媒体营销-东莞市凌天信息科技有限公司 | 山东信蓝建设有限公司官网 | 全自动在线分板机_铣刀式在线分板机_曲线分板机_PCB分板机-东莞市亿协自动化设备有限公司 | 电动葫芦-河北悍象起重机械有限公司 | 电子元器件呆滞料_元器件临期库存清仓尾料_尾料优选现货采购处理交易商城 | 细胞染色-流式双标-试剂盒免费代做-上海研谨生物科技有限公司 | 股票入门基础知识_股票知识_股票投资大师_格雷厄姆网 | 新中天检测有限公司青岛分公司-山东|菏泽|济南|潍坊|泰安防雷检测验收 | 耐压仪-高压耐压仪|徐吉电气 | 搪瓷搅拌器,搪玻璃搅拌器,搪玻璃冷凝器_厂家-淄博越宏化工设备 | 二次元影像仪|二次元测量仪|拉力机|全自动影像测量仪厂家_苏州牧象仪器 | SMC-ASCO-CKD气缸-FESTO-MAC电磁阀-上海天筹自动化设备官网 | 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 济南玻璃安装_济南玻璃门_济南感应门_济南玻璃隔断_济南玻璃门维修_济南镜片安装_济南肯德基门_济南高隔间-济南凯轩鹏宇玻璃有限公司 | 可程式恒温恒湿试验箱|恒温恒湿箱|恒温恒湿试验箱|恒温恒湿老化试验箱|高低温试验箱价格报价-广东德瑞检测设备有限公司 | 袋式过滤器,自清洗过滤器,保安过滤器,篮式过滤器,气体过滤器,全自动过滤器,反冲洗过滤器,管道过滤器,无锡驰业环保科技有限公司 | 膜结构_ETFE膜结构_膜结构厂家_膜结构设计-深圳市烨兴智能空间技术有限公司 | sfp光模块,高速万兆光模块工厂-性价比更高的光纤模块制造商-武汉恒泰通 | 美侍宠物-专注宠物狗及宠物猫训练|喂养|医疗|繁育|品种|价格 | 广西资质代办_建筑资质代办_南宁资质代办理_新办、增项、升级-正明集团 | 旋振筛|圆形摇摆筛|直线振动筛|滚筒筛|压榨机|河南天众机械设备有限公司 | 充气膜专家-气膜馆-PTFE膜结构-ETFE膜结构-商业街膜结构-奥克金鼎 | 铸铁平台,大理石平台专业生产厂家_河北-北重机械 | 直流大电流电源,燃料电池检漏设备-上海政飞 | 蔬菜配送公司|蔬菜配送中心|食材配送|饭堂配送|食堂配送-首宏公司 | 水质监测站_水质在线分析仪_水质自动监测系统_多参数水质在线监测仪_水质传感器-山东万象环境科技有限公司 | 超声波清洗机_大型超声波清洗机_工业超声波清洗设备-洁盟清洗设备 | 喷播机厂家_二手喷播机租赁_水泥浆洒布机-河南青山绿水机电设备有限公司 | 上海洗地机-洗地机厂家-全自动洗地机-手推式洗地机-上海滢皓洗地机 | 自动部分收集器,进口无油隔膜真空泵,SPME固相微萃取头-上海楚定分析仪器有限公司 | 结晶点测定仪-润滑脂滴点测定仪-大连煜烁 | 辐射仪|辐射检测仪|辐射巡测仪|个人剂量报警仪|表面污染检测仪|辐射报警仪|辐射防护网 | 防弹玻璃厂家_防爆炸玻璃_电磁屏蔽玻璃-四川大硅特玻科技有限公司 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 福建成考网-福建成人高考网| uv机-uv灯-uvled光固化机-生产厂家-蓝盾机电 |