python線程優先順序隊列是什嗎?線程優先順序的設定方法有哪些?

來源:互聯網
上載者:User
對於第一次接觸到python這門程式設計語言的朋友來說,剛剛開始學習python編程的時候對於python線程這一方面的瞭解比較少,在這篇文章之中我們就來瞭解一下python 線程優先順序以及python 線程優先順序設定方面的知識。

線程優先順序隊列(Queue)

Python的Queue模組中提供了同步的、安全執行緒的隊列類,包括FIFO(先入先出)隊列Queue,LIFO(後入先出)隊列LifoQueue,和優先順序隊列PriorityQueue。這些隊列都實現了鎖原語,能夠在多線程中直接使用。可以使用隊列來實現線程間的同步。

Queue模組中的常用方法:

1.Queue.qsize() 返回隊列的大小

2.Queue.empty() 如果隊列為空白,返回True,反之False

3.Queue.full() 如果隊列滿了,返回True,反之False

4.Queue.full 與 maxsize 大小對應

5.Queue.get([block[, timeout]])擷取隊列,timeout等待時間

6.Queue.get_nowait() 相當Queue.get(False)

7.Queue.put(item) 寫入隊列,timeout等待時間

8.Queue.put_nowait(item) 相當Queue.put(item, False)

9.Queue.task_done() 在完成一項工作之後,Queue.task_done()函數向任務已經完成的隊列發送一個訊號

10.Queue.join() 實際上意味著等到隊列為空白,再執行別的操作

舉例如下:

# !/usr/bin/python# -*- coding: UTF-8 -*-import Queueimport threadingimport timeexitFlag = 0class myThread(threading.Thread):   def __init__(self, threadID, name, q):      threading.Thread.__init__(self)      self.threadID = threadID      self.name = name      self.q = q   def run(self):      print "Starting " + self.name      process_data(self.name, self.q)      print "Exiting " + self.namedef process_data(threadName, q):   while not exitFlag:      queueLock.acquire()      if not workQueue.empty():         data = q.get()         queueLock.release()         print "%s processing %s" % (threadName, data)      else:         queueLock.release()      time.sleep(1)threadList = ["Thread-1", "Thread-2", "Thread-3"]nameList = ["One", "Two", "Three", "Four", "Five"]queueLock = threading.Lock()workQueue = Queue.Queue(10)threads = []threadID = 1# 建立新線程for tName in threadList:   thread = myThread(threadID, tName, workQueue)   thread.start()   threads.append(thread)   threadID += 1# 填充隊列queueLock.acquire()for word in nameList:   workQueue.put(word)queueLock.release()# 等待隊列清空while not workQueue.empty():   pass# 通知線程是時候退出exitFlag = 1# 等待所有線程完成for t in threads:   t.join()print "Exiting Main Thread"

以上執行個體所輸出的結果如下:

Starting Thread-1Starting Thread-2Starting Thread-3Thread-1 processing OneThread-2 processing TwoThread-3 processing ThreeThread-1 processing FourThread-2 processing FiveExiting Thread-3Exiting Thread-1Exiting Thread-2Exiting Main Thread
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.