Python進程間通信:Queue


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 python3

import time
from multiprocessing import Process,Queue

q = 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 :
            break

def B():
    while 1:
        try:
            num = q.get_nowait()
            print('我是進程B,取出數字:%d'%num)
            time.sleep(1)
        except :
            break

p1 = 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 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,取出數字:%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(),可能會出現資源混亂,缺少進程。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM