Python進程間通信Queue實例解析
本文研究的主要是Python進程間通信Queue的相關(guān)實例,具體如下。
1.Queue使用方法:
- Queue.qsize():返回當(dāng)前隊列包含的消息數(shù)量;
- Queue.empty():如果隊列為空,返回True,反之False ;
- Queue.full():如果隊列滿了,返回True,反之False;
- Queue.get():獲取隊列中的一條消息,然后將其從列隊中移除,可傳參超時時長。
- Queue.get_nowait():相當(dāng)Queue.get(False),取不到值時觸發(fā)異常:Empty;
- Queue.put():將一個值添加進數(shù)列,可傳參超時時長。
- Queue.put_nowait():相當(dāng)于Queue.get(False),當(dāng)隊列滿了時報錯:Full。
2.Queue使用實例:
來,上代碼:
#!/usr/bin/env python3
import time
from multiprocessing import Process,Queue
q = Queue() #創(chuàng)建列隊,不傳數(shù)字表示列隊不限數(shù)量
for i in range(11):
q.put(i)
def A():
while 1:
try:
num = q.get_nowait()
print('我是進程A,取出數(shù)字:%d'%num)
time.sleep(1)
except :
break
def B():
while 1:
try:
num = q.get_nowait()
print('我是進程B,取出數(shù)字:%d'%num)
time.sleep(1)
except :
break
p1 = Process(target = A)
p2 = Process(target = B)
p1.start()
p2.start()
此程序是在隊列中加入10個數(shù)字,然后用2個進程來取出。
運行結(jié)果:
我是進程A,取出數(shù)字:0
我是進程B,取出數(shù)字:1
我是進程A,取出數(shù)字:2
我是進程B,取出數(shù)字:3
我是進程A,取出數(shù)字:4
我是進程B,取出數(shù)字:5
我是進程B,取出數(shù)字:6
我是進程A,取出數(shù)字:7
我是進程B,取出數(shù)字:8
我是進程A,取出數(shù)字:9
我是進程B,取出數(shù)字:10
3.使用進程池Pool時,Queue會出錯,需要使用Manager.Queue:
上代碼
#!/usr/bin/env python3
import time
from multiprocessing import Pool,Manager,Queue
q = Manager().Queue()
for i in range(11):
q.put(i)
def A(i):
num = q.get_nowait()
print('我是進程%d,取出數(shù)字:%d'%(i,num))
time.sleep(1)
pool = Pool(3)
for i in range(10):
pool.apply_async(A,(i,))
pool.close()
pool.join()
運行結(jié)果:
我是進程1,取出數(shù)字:0
我是進程0,取出數(shù)字:1
我是進程2,取出數(shù)字:2
我是進程4,取出數(shù)字:3
我是進程3,取出數(shù)字:4
我是進程5,取出數(shù)字:5
我是進程6,取出數(shù)字:6
我是進程7,取出數(shù)字:7
我是進程8,取出數(shù)字:8
我是進程9,取出數(shù)字:9
當(dāng)把Manager().Queue()直接換成Queue(),可能會出現(xiàn)資源混亂,缺少進程。
4.主進程定義了一個Queue類型的變量,并作為Process的args參數(shù)傳給子進程processA和processB,兩個進程一個向隊列中寫數(shù)據(jù),一個讀數(shù)據(jù)。
import time
from multiprocessing import Process,Queue
MSG_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..'
其打印的結(jié)果如下:
C:\Python27\python.exe E:/outofmemory/test/queuetest/queuetest.py
processA start..
processB start..
queue is empty 0
put hello world queue size is 1
get msg hello world
queue is empty 0
queue is empty 0
put hello world queue size is 1
get msg hello world
queue is empty 0
queue is empty 0
put hello world queue size is 1
總結(jié)
以上就是本文關(guān)于Python進程間通信Queue實例解析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
python 讀寫txt文件 json文件的實現(xiàn)方法
下面小編就為大家?guī)硪黄猵ython 讀寫、創(chuàng)建 文件的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10
通過Python編程將CSV文件導(dǎo)出為PDF文件的方法
CSV文件通常用于存儲大量的數(shù)據(jù),而PDF文件則是一種通用的文檔格式,便于與他人共享和打印,將CSV文件轉(zhuǎn)換成PDF文件可以幫助我們更好地管理和展示數(shù)據(jù),本文將介紹如何通過Python編程將CSV文件導(dǎo)出為PDF文件,需要的朋友可以參考下2024-06-06
Python DBM模塊輕松使用小型數(shù)據(jù)庫存儲管理數(shù)據(jù)
這篇文章主要介紹了Python DBM模塊輕松使用小型數(shù)據(jù)庫存儲管理數(shù)據(jù),它可以讓你輕松地存儲和管理鍵值對數(shù)據(jù),可以使用 dbm 模塊來操作 DBM 文件,或者使用 shelve 模塊來存儲任意類型的 Python 對象2024-01-01
python實現(xiàn)視頻讀取和轉(zhuǎn)化圖片
今天小編就為大家分享一篇python實現(xiàn)視頻讀取和轉(zhuǎn)化圖片,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12

