Python多線程(3)——Queue模組

來源:互聯網
上載者:User

標籤:

  Queue模組支援先進先出(FIFO)隊列,支援多線程的訪問,包括一個主要的類型(Queue)和兩個異常類(exception classes)。

  Python 2 中的Queue模組在Python 3中更名為 queue。

 

Queue對象的建立

  可以通過執行個體化Queue類型獲得隊列對象:

q = Queue.Queue(maxsize=0)

  建立新的隊列,參數 maxsize 的含義是:

  • 如果 maxsize > 0:當 q 中的元素達到 maxsize 個時,隊列就滿了,此時再有一個線程希望向裡面插入時,如果指定了 block 選項,就會阻塞直到一個線程從裡面抽出一個元素。
  • 如果 maxsize <= 0:Python會認為這是一個沒有容量限制的隊列。

 

Queue模組定義的異常類

Queue.Empty

  如果隊列 q 是空的,此時又調用了 q.get(False),就會拋出該異常。

 

Queue.Full

  如果隊列q是滿的,而又調用了 q.put(x, False),就會拋出該異常。

 

Queue對象的方法

q.empty()

   判斷隊列是否為空白。

 

q.full()

   判斷隊列是否已滿。

 

q.get(block=True, timeout=None)q.get_nowait()

  參數 block 為 False 時,參數 timeout 沒有意義,因為線程不會阻塞:

  • 如果隊列不為空白,取走並返回該元素;
  • 如果隊列為空白,拋出Queue.Empty

  block 為 True 時,結合逾時 timeout 判斷當隊列空時,是一直阻塞進程,還是進程阻塞一段時間。

  get_nowait()等於get(False),或者get(timeout=0)即不論隊列空否,都不阻塞等待。

例如:

try:    x = q.get_nowait()except Queue.Empty:    print "no more items to process"

  

q.put(item, block=True, timeout=None)q.put_nowait(item)

  向隊列中插入 item,如果隊列滿了,拋出Queue.Full或線程阻塞等待。

 

q.qsize()

  返回當前隊列中的元素個數。

 

q.join()

 

q.task_done()

 

Python多線程(3)——Queue模組

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.