国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python進程間通信Queue實例解析

2020-02-22 22:59:39
字體:
來源:轉載
供稿:網友

本文研究的主要是Python進程間通信Queue的相關實例,具體如下。

1.Queue使用方法:

Queue.qsize():返回當前隊列包含的消息數量; Queue.empty():如果隊列為空,返回True,反之False ; Queue.full():如果隊列滿了,返回True,反之False; Queue.get():獲取隊列中的一條消息,然后將其從列隊中移除,可傳參超時時長。 Queue.get_nowait():相當Queue.get(False),取不到值時觸發異常:Empty; Queue.put():將一個值添加進數列,可傳參超時時長。 Queue.put_nowait():相當于Queue.get(False),當隊列滿了時報錯:Full。

2.Queue使用實例:

來,上代碼:

#!/usr/bin/env python3import timefrom multiprocessing import Process,Queueq = Queue() #創建列隊,不傳數字表示列隊不限數量for i in range(11):  q.put(i)def A():  while 1:    try:      num = q.get_nowait()      print('我是進程A,取出數字:%d'%num)      time.sleep(1)    except :      breakdef B():  while 1:    try:      num = q.get_nowait()      print('我是進程B,取出數字:%d'%num)      time.sleep(1)    except :      breakp1 = Process(target = A)p2 = Process(target = B)p1.start()p2.start()

此程序是在隊列中加入10個數字,然后用2個進程來取出。

運行結果:

我是進程A,取出數字:0
我是進程B,取出數字:1
我是進程A,取出數字:2
我是進程B,取出數字:3
我是進程A,取出數字:4
我是進程B,取出數字:5
我是進程B,取出數字:6
我是進程A,取出數字:7
我是進程B,取出數字:8
我是進程A,取出數字:9
我是進程B,取出數字:10

3.使用進程池Pool時,Queue會出錯,需要使用Manager.Queue:

上代碼

#!/usr/bin/env python3import timefrom multiprocessing import Pool,Manager,Queueq = Manager().Queue()for i in range(11):  q.put(i)def A(i):  num = q.get_nowait()  print('我是進程%d,取出數字:%d'%(i,num))  time.sleep(1)      pool = Pool(3)for i in range(10):  pool.apply_async(A,(i,))pool.close()pool.join()

運行結果:

我是進程1,取出數字:0
我是進程0,取出數字:1
我是進程2,取出數字:2
我是進程4,取出數字:3
我是進程3,取出數字:4
我是進程5,取出數字:5
我是進程6,取出數字:6
我是進程7,取出數字:7
我是進程8,取出數字:8
我是進程9,取出數字:9

當把Manager().Queue()直接換成Queue(),可能會出現資源混亂,缺少進程。

4.主進程定義了一個Queue類型的變量,并作為Process的args參數傳給子進程processA和processB,兩個進程一個向隊列中寫數據,一個讀數據。

import timefrom multiprocessing import Process,QueueMSG_QUEUE = Queue(5)def startA(msgQueue):  while True:    if msgQueue.empty() > 0:      print 'queue is empty %d' % (msgQueue.qsize())    else:      msg = msgQueue.get()      print 'get msg %s' % (msg,)    time.sleep(1)def startB(msgQueue):  while True:    msgQueue.put('hello world')    print 'put hello world queue size is %d' % (msgQueue.qsize(),)    time.sleep(3)if __name__ == '__main__':  processA = Process(target=startA,args=(MSG_QUEUE,))  processB = Process(target=startB,args=(MSG_QUEUE,))  processA.start()  print 'processA start..'  processB.start()  print 'processB start..'            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 林州市| 新兴县| 阳新县| 舒兰市| 平舆县| 宿松县| 文化| 石城县| 巴中市| 化德县| 呈贡县| 桓台县| 岐山县| 桐城市| 凯里市| 周至县| 定日县| 射阳县| 定日县| 中超| 新龙县| 固原市| 襄汾县| 和平区| 卢湾区| 桃园县| 手机| 淄博市| 洛宁县| 桃园县| 连云港市| 宜良县| 海盐县| 丹寨县| 麦盖提县| 原平市| 虎林市| 故城县| 新闻| 云浮市| 南安市|