詳解Python 模擬實現(xiàn)生產(chǎn)者消費者模式的實例
詳解Python 模擬實現(xiàn)生產(chǎn)者消費者模式的實例
散仙使用python3.4模擬實現(xiàn)的一個生產(chǎn)者與消費者的例子,用到的知識有線程,隊列,循環(huán)等,源碼如下:
Python代碼
import queue import time import threading import random q=queue.Queue(5) #生產(chǎn)者 def pr(): name=threading.current_thread().getName() print(name+"線程啟動......") for i in range(100): t=random.randint(2,9) print(name,"睡眠時間: ",t) time.sleep(t); d="A"+str(i) print(name+"正在存第",i+1,"個數(shù)據(jù): ",d) #q.put("A"+str(i),False,2000) q.put(d) print("生產(chǎn)完畢!") #消費者 def co(): name=threading.current_thread().getName() time.sleep(1) print(name+"線程啟動......") while True: print(name+"檢測到隊列數(shù)量: ",q.qsize()) t=random.randint(2,9) print(name,"睡眠時間: ",t) data=q.get(); print(name+"消費一個數(shù)據(jù): ",data) p=threading.Thread(target=pr,name="生產(chǎn)者") c=threading.Thread(target=co,name="消費者1") c2=threading.Thread(target=co,name="消費者2") p.start() c.start() c2.start()
在本例里面散仙啟動了1個生產(chǎn)者線程,2個消費者線程,打印效果如下:
Python代碼
生產(chǎn)者線程啟動...... 生產(chǎn)者 睡眠時間: 4 消費者1線程啟動...... 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 2 消費者2線程啟動...... 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 3 生產(chǎn)者正在存第 1 個數(shù)據(jù): A0 生產(chǎn)者 睡眠時間: 9 消費者1消費一個數(shù)據(jù): A0 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 8 生產(chǎn)者正在存第 2 個數(shù)據(jù): A1 生產(chǎn)者 睡眠時間: 5 消費者2消費一個數(shù)據(jù): A1 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 7 生產(chǎn)者正在存第 3 個數(shù)據(jù): A2 生產(chǎn)者 睡眠時間: 8 消費者1消費一個數(shù)據(jù): A2 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 2 生產(chǎn)者正在存第 4 個數(shù)據(jù): A3 生產(chǎn)者 睡眠時間: 7 消費者2消費一個數(shù)據(jù): A3 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 9 生產(chǎn)者正在存第 5 個數(shù)據(jù): A4 生產(chǎn)者 睡眠時間: 2 消費者1消費一個數(shù)據(jù): A4 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 5 生產(chǎn)者正在存第 6 個數(shù)據(jù): A5 生產(chǎn)者 睡眠時間: 5 消費者2消費一個數(shù)據(jù): A5 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 6 生產(chǎn)者正在存第 7 個數(shù)據(jù): A6 生產(chǎn)者 睡眠時間: 7 消費者1消費一個數(shù)據(jù): A6 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 7 生產(chǎn)者正在存第 8 個數(shù)據(jù): A7 生產(chǎn)者 睡眠時間: 3 消費者2消費一個數(shù)據(jù): A7 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 8 生產(chǎn)者正在存第 9 個數(shù)據(jù): A8 生產(chǎn)者 睡眠時間: 2 消費者1消費一個數(shù)據(jù): A8 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 4 生產(chǎn)者正在存第 10 個數(shù)據(jù): A9 生產(chǎn)者 睡眠時間: 4 消費者2消費一個數(shù)據(jù): A9 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 5 生產(chǎn)者正在存第 11 個數(shù)據(jù): A10 生產(chǎn)者 睡眠時間: 2 消費者1消費一個數(shù)據(jù): A10 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 3 生產(chǎn)者正在存第 12 個數(shù)據(jù): A11 生產(chǎn)者 睡眠時間: 3 消費者2消費一個數(shù)據(jù): A11 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 3 生產(chǎn)者正在存第 13 個數(shù)據(jù): A12 生產(chǎn)者 睡眠時間: 3 消費者1消費一個數(shù)據(jù): A12 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 3 生產(chǎn)者正在存第 14 個數(shù)據(jù): A13 生產(chǎn)者 睡眠時間: 8 消費者2消費一個數(shù)據(jù): A13 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 7 生產(chǎn)者正在存第 15 個數(shù)據(jù): A14 生產(chǎn)者 睡眠時間: 3 消費者1消費一個數(shù)據(jù): A14 消費者1檢測到隊列數(shù)量: 0 消費者1 睡眠時間: 7 生產(chǎn)者正在存第 16 個數(shù)據(jù): A15 生產(chǎn)者 睡眠時間: 2 消費者2消費一個數(shù)據(jù): A15 消費者2檢測到隊列數(shù)量: 0 消費者2 睡眠時間: 9
從這個例子中,我們發(fā)現(xiàn)利用隊列,來做同步時非常簡單方便的,除此之外隊列,還有如下幾個方便的方法:
介紹一下此包中的常用方法:
Queue.qsize() 返回隊列的大小 Queue.empty() 如果隊列為空,返回True,反之False Queue.full() 如果隊列滿了,返回True,反之False Queue.full 與 maxsize 大小對應(yīng) Queue.get([block[, timeout]])獲取隊列,timeout等待時間 Queue.get_nowait() 相當(dāng)Queue.get(False) 非阻塞 Queue.put(item) 寫入隊列,timeout等待時間 Queue.put_nowait(item) 相當(dāng)Queue.put(item, False) Queue.task_done() 在完成一項工作之后,Queue.task_done()函數(shù)向任務(wù)已經(jīng)完成的隊列發(fā)送一個信號 Queue.join() 實際上意味著等到隊列為空,再執(zhí)行別的操作
以上就是詳解Python 模擬實現(xiàn)生產(chǎn)者消費者模式的實例,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
python 使用pygame工具包實現(xiàn)貪吃蛇游戲(多彩版)
這篇文章主要介紹了python 使用pygame工具包實現(xiàn)貪吃蛇游戲,本篇給大家分享的是一個多彩版,通過實例代碼給大家講解,非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-10-10Python3實現(xiàn)將一維數(shù)組按標(biāo)準(zhǔn)長度分隔為二維數(shù)組
今天小編就為大家分享一篇Python3實現(xiàn)將一維數(shù)組按標(biāo)準(zhǔn)長度分隔為二維數(shù)組,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11python利用hook技術(shù)破解https的實例代碼
python利用hook技術(shù)破解https的實例代碼,需要的朋友可以參考一下2013-03-03