亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

python 隊列詳解及實例代碼

系統 2176 0

隊列特性: 先進先出(FIFO)――先進隊列的元素先出隊列。來源于我們生活中的隊列(先排隊的先辦完事)。

python 隊列詳解及實例代碼_第1張圖片

Queue模塊最常與threading模塊一起構成生產-消費者模型,提供了一個適用于多線程編程的先進先出的數據結構,即隊列。

該模塊源碼中包含5個類:

其中,Empty和Full是兩個異常類,當隊列的Queue.get(block=0)或者調用get_nowait()時,如果隊列為空,則拋EmptyException異常。

   同理,當隊列的Queue.put(block=0)或者調用put_nowait()時,如果隊列為達到maxsize,則拋FullException異常。

其他三個類:

Queue類 :典型的隊列模型,FIFO先入先出。  class Queue.Queue(maxsize)???? maxsize為隊列長度,指明了隊列中能存放的數據個數的上限。一旦達到上限,插入會導致阻??????????????????????????????????????????????????????????????????????????????????????????????????????????????? 塞,

直到隊列中的數據被消費掉。如果maxsize小于或者等于0,隊列大小沒有限制。

LifoQueue類 :繼承自Queue,類似于堆棧,先入后出。  class Queue.LifoQueue(maxsize)

PriorityQueue類 :繼承自Queue,優先級隊列,級別越低越先出來。  class Queue.PriorityQueue(maxsize)

所以,只要搞定Queue類,就基本搞定Queue模塊。

Queue類中常用的方法:

Queue.qsize()   ??       返回隊列的大小
Queue.empty()          如果隊列為空,返回True,反之False
Queue.full()           如果隊列滿了,返回True,反之False
Queue.full           ?? 與 maxsize 大小對應

Queue.get([block[, timeout]])??? 獲取隊列,timeout等待時間 ,調用隊列對象的get()方法從隊頭刪除并返回一個項目。可選參數為block,默認為True。如果隊列為空且block為True,get()就使調用線程暫停,直至有項目可用。如果隊列為空且block為False,隊列將引發Empty異常。

Queue.get_nowait()??? ?相當于 Queue.get(False)

Queue.put(item)

??寫入隊列,timeout等待時間 ,調用隊列對象的put()方法在隊尾插入一個項目。put()有兩個參數,第一個item為必需的,為插入項目的值;第?? 二個block為可選參數,默認為1。如果隊列當前為空且block為1,put()方法就使調用線程暫停,直到空出一個數據單元。如果block為0,put方法將引發Full異常。????????????????????????????????????????????

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

Queue.task_done()

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

Queue.join()

?實際上意味著等到隊列為空,再執行別的操作

一個小的練習實例:

            
#coding:utf-8
import random, threading, time
import Queue
'''
實現了一個生產線程,用于往隊列中添加隨機數10個,
實現了一個消費線程,分別消耗奇數隨機數和偶數隨機數
'''

class producer(threading.Thread):
  def __init__(self,t_name,queue):
    threading.Thread.__init__(self,name=t_name)
    self.data = queue
  def run(self):
    for i in xrange(10):
      random_num = random.randint(1,99)
      print "%s : %s 生產了一個隨機數\033[31;0m %d \033[0m放入隊列中" % (time.ctime(),self.getName(),random_num)
      self.data.put(random_num)
      time.sleep(1)
    print "生產線程完成!!"


class consumer(threading.Thread):
  def __init__(self,t_name,queue):
    threading.Thread.__init__(self,name=t_name)
    self.data = queue
  def run(self):
    while True:
      try:
        tmp_num = self.data.get(1,5) #定義超時時間5秒
        if tmp_num%2 == 0:
          print "%s : %s 消耗了一個隊列中的偶數隨機數\033[31;0m %d \033[0m" % (time.ctime(),self.getName(),tmp_num)
          time.sleep(2)
        else:
          print "%s : %s 消耗了一個隊列中的奇數隨機數\033[31;0m %d \033[0m" % (time.ctime(), self.getName(), tmp_num)
          time.sleep(2)
      except:
        print "消費線程完成!!" #一旦到達超時時間5秒,會拋異常,break退出循環
        break


def main():
  queue = Queue.Queue(0)
  pro = producer('Pro', queue)
  con = consumer('Con', queue)
  pro.start()
  con.start()
  pro.join()
  con.join()
  print 'All threads complete!!!'

if __name__ == '__main__':
  main()
          

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲视频在线观看免费视频 | 精品久久久久久婷婷 | 中文字幕久久精品波多野结 | 亚洲国产aaa毛片无费看 | 99热久久这里只有精品7 | 欧美性大战久久久久久久蜜桃 | 99国产精品高清一区二区二区 | 色妞bbbb女女女女 | 夜夜骑日日操 | 国产大片中文字幕在线观看 | 亚洲国产人久久久成人精品网站 | 桃花福利视频在线观看 | 亚洲在线小视频 | 一区二区美女视频 | 国产日韩久久久精品影院首页 | 久久老色鬼天天综合网观看 | 国产午夜亚洲精品国产 | 欧美精品在欧美一区二区 | 免费看欧美一级特黄α大片 | 青青青线在线观看 | 国产午夜不卡 | 亚洲一区中文字幕 | 99久久精品费精品国产一区二 | 在线第一福利视频观看 | 日本一区精品久久久久影院 | 国自产拍在线天天更新2019 | 色拍拍欧美视频在线看 | 国产精品久久久久久久久久98 | 日本免费高清一级毛片 | 欧美高清日韩 | 久操国产 | 青青爽国产手机在线观看免费 | 九九热视频在线观看 | 欧美激情欧美狂野欧美精品免费 | 国产成人亚洲精品乱码在线观看 | 黄色成人在线视频 | 国产成人刺激视频在线观看 | 四虎影院网址大全 | 亚洲色图国产精品 | 天天在线综合网 | 99久久99久久精品免费看蜜桃 |