欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python 隊(duì)列詳解及實(shí)例代碼

 更新時(shí)間:2016年10月18日 12:01:32   投稿:lqh  
這篇文章主要介紹了python 隊(duì)列詳解的相關(guān)資料,并附簡(jiǎn)單實(shí)例代碼,幫助大家學(xué)習(xí)了解數(shù)據(jù)結(jié)構(gòu)的隊(duì)列,需要的朋友可以參考下

隊(duì)列特性:先進(jìn)先出(FIFO)——先進(jìn)隊(duì)列的元素先出隊(duì)列。來(lái)源于我們生活中的隊(duì)列(先排隊(duì)的先辦完事)。

Queue模塊最常與threading模塊一起構(gòu)成生產(chǎn)-消費(fèi)者模型,提供了一個(gè)適用于多線程編程的先進(jìn)先出的數(shù)據(jù)結(jié)構(gòu),即隊(duì)列。

該模塊源碼中包含5個(gè)類:

其中,Empty和Full是兩個(gè)異常類,當(dāng)隊(duì)列的Queue.get(block=0)或者調(diào)用get_nowait()時(shí),如果隊(duì)列為空,則拋EmptyException異常。

   同理,當(dāng)隊(duì)列的Queue.put(block=0)或者調(diào)用put_nowait()時(shí),如果隊(duì)列為達(dá)到maxsize,則拋FullException異常。

其他三個(gè)類:

Queue類:典型的隊(duì)列模型,F(xiàn)IFO先入先出?! lass Queue.Queue(maxsize)     maxsize為隊(duì)列長(zhǎng)度,指明了隊(duì)列中能存放的數(shù)據(jù)個(gè)數(shù)的上限。一旦達(dá)到上限,插入會(huì)導(dǎo)致阻                                                                                                                塞,

直到隊(duì)列中的數(shù)據(jù)被消費(fèi)掉。如果maxsize小于或者等于0,隊(duì)列大小沒(méi)有限制。

LifoQueue類:繼承自Queue,類似于堆棧,先入后出?! lass Queue.LifoQueue(maxsize)

PriorityQueue類:繼承自Queue,優(yōu)先級(jí)隊(duì)列,級(jí)別越低越先出來(lái)?! lass Queue.PriorityQueue(maxsize)

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

Queue類中常用的方法:

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

Queue.get([block[, timeout]])    獲取隊(duì)列,timeout等待時(shí)間 ,調(diào)用隊(duì)列對(duì)象的get()方法從隊(duì)頭刪除并返回一個(gè)項(xiàng)目??蛇x參數(shù)為block,默認(rèn)為T(mén)rue。如果隊(duì)列為空且block為T(mén)rue,get()就使調(diào)用線程暫停,直至有項(xiàng)目可用。如果隊(duì)列為空且block為False,隊(duì)列將引發(fā)Empty異常。

Queue.get_nowait()    相當(dāng)于Queue.get(False)

Queue.put(item)

  寫(xiě)入隊(duì)列,timeout等待時(shí)間 ,調(diào)用隊(duì)列對(duì)象的put()方法在隊(duì)尾插入一個(gè)項(xiàng)目。put()有兩個(gè)參數(shù),第一個(gè)item為必需的,為插入項(xiàng)目的值;第   二個(gè)block為可選參數(shù),默認(rèn)為1。如果隊(duì)列當(dāng)前為空且block為1,put()方法就使調(diào)用線程暫停,直到空出一個(gè)數(shù)據(jù)單元。如果block為0,put方法將引發(fā)Full異常。                                            

Queue.put_nowait(item) 相當(dāng)Queue.put(item, False)

Queue.task_done()

  在完成一項(xiàng)工作之后,Queue.task_done()函數(shù)向任務(wù)已經(jīng)完成的隊(duì)列發(fā)送一個(gè)信號(hào)

Queue.join()

 實(shí)際上意味著等到隊(duì)列為空,再執(zhí)行別的操作

一個(gè)小的練習(xí)實(shí)例:

#coding:utf-8
import random, threading, time
import Queue
'''
實(shí)現(xiàn)了一個(gè)生產(chǎn)線程,用于往隊(duì)列中添加隨機(jī)數(shù)10個(gè),
實(shí)現(xiàn)了一個(gè)消費(fèi)線程,分別消耗奇數(shù)隨機(jī)數(shù)和偶數(shù)隨機(jī)數(shù)
'''

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 生產(chǎn)了一個(gè)隨機(jī)數(shù)\033[31;0m %d \033[0m放入隊(duì)列中" % (time.ctime(),self.getName(),random_num)
      self.data.put(random_num)
      time.sleep(1)
    print "生產(chǎn)線程完成??!"


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) #定義超時(shí)時(shí)間5秒
        if tmp_num%2 == 0:
          print "%s : %s 消耗了一個(gè)隊(duì)列中的偶數(shù)隨機(jī)數(shù)\033[31;0m %d \033[0m" % (time.ctime(),self.getName(),tmp_num)
          time.sleep(2)
        else:
          print "%s : %s 消耗了一個(gè)隊(duì)列中的奇數(shù)隨機(jī)數(shù)\033[31;0m %d \033[0m" % (time.ctime(), self.getName(), tmp_num)
          time.sleep(2)
      except:
        print "消費(fèi)線程完成??!" #一旦到達(dá)超時(shí)時(shí)間5秒,會(huì)拋異常,break退出循環(huán)
        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()

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

相關(guān)文章

  • python獲取域名ssl證書(shū)信息和到期時(shí)間

    python獲取域名ssl證書(shū)信息和到期時(shí)間

    這篇文章主要為大家詳細(xì)介紹了如何利用python實(shí)現(xiàn)獲取域名ssl證書(shū)信息和到期時(shí)間,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下
    2023-09-09
  • python實(shí)現(xiàn)拼接圖片

    python實(shí)現(xiàn)拼接圖片

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)拼接圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 自己搭建resnet18網(wǎng)絡(luò)并加載torchvision自帶權(quán)重的操作

    自己搭建resnet18網(wǎng)絡(luò)并加載torchvision自帶權(quán)重的操作

    這篇文章主要介紹了自己搭建resnet18網(wǎng)絡(luò)并加載torchvision自帶權(quán)重的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python tkinter實(shí)現(xiàn)日期選擇器

    Python tkinter實(shí)現(xiàn)日期選擇器

    這篇文章主要為大家詳細(xì)介紹了Python tkinter實(shí)現(xiàn)日期選擇器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • Python3單行定義多個(gè)變量或賦值方法

    Python3單行定義多個(gè)變量或賦值方法

    今天小編就為大家分享一篇Python3單行定義多個(gè)變量或賦值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • python pytest進(jìn)階之conftest.py詳解

    python pytest進(jìn)階之conftest.py詳解

    這篇文章主要介紹了python pytest進(jìn)階之conftest.py詳解,如果我們?cè)诰帉?xiě)測(cè)試用的時(shí)候,每一個(gè)測(cè)試文件里面的用例都需要先登錄后才能完成后面的操作,那么們?cè)撊绾螌?shí)現(xiàn)呢?這就需要我們掌握conftest.py文件的使用了,需要的朋友可以參考下
    2019-06-06
  • python如何在循環(huán)引用中管理內(nèi)存

    python如何在循環(huán)引用中管理內(nèi)存

    這篇文章主要為大家詳細(xì)介紹了python如何在循環(huán)引用中管理內(nèi)存,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Python調(diào)用golang代碼詳解

    Python調(diào)用golang代碼詳解

    這篇文章主要給大家介紹了關(guān)于Python調(diào)用golang代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-02-02
  • 在python中使用nohup命令說(shuō)明

    在python中使用nohup命令說(shuō)明

    這篇文章主要介紹了在python中使用nohup命令說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-04-04
  • Python中使用threading.Event協(xié)調(diào)線程的運(yùn)行詳解

    Python中使用threading.Event協(xié)調(diào)線程的運(yùn)行詳解

    這篇文章主要介紹了Python中使用threading.Event協(xié)調(diào)線程的運(yùn)行詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-05-05

最新評(píng)論