国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

詳解Python 模擬實現生產者消費者模式的實例

2019-11-25 15:56:53
字體:
來源:轉載
供稿:網友

詳解Python 模擬實現生產者消費者模式的實例

散仙使用python3.4模擬實現的一個生產者與消費者的例子,用到的知識有線程,隊列,循環等,源碼如下:

Python代碼

import queue import time import threading import random   q=queue.Queue(5)  #生產者 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,"個數據: ",d)     #q.put("A"+str(i),False,2000)     q.put(d)   print("生產完畢!")   #消費者 def co():   name=threading.current_thread().getName()   time.sleep(1)   print(name+"線程啟動......")    while True:     print(name+"檢測到隊列數量: ",q.qsize())     t=random.randint(2,9)     print(name,"睡眠時間: ",t)     data=q.get();     print(name+"消費一個數據: ",data)     p=threading.Thread(target=pr,name="生產者") c=threading.Thread(target=co,name="消費者1") c2=threading.Thread(target=co,name="消費者2")  p.start() c.start() c2.start() 

在本例里面散仙啟動了1個生產者線程,2個消費者線程,打印效果如下:

Python代碼 

生產者線程啟動...... 生產者 睡眠時間: 4 消費者1線程啟動...... 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 2 消費者2線程啟動...... 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 3 生產者正在存第 1 個數據: A0 生產者 睡眠時間: 9 消費者1消費一個數據: A0 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 8 生產者正在存第 2 個數據: A1 生產者 睡眠時間: 5 消費者2消費一個數據: A1 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 7 生產者正在存第 3 個數據: A2 生產者 睡眠時間: 8 消費者1消費一個數據: A2 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 2 生產者正在存第 4 個數據: A3 生產者 睡眠時間: 7 消費者2消費一個數據: A3 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 9 生產者正在存第 5 個數據: A4 生產者 睡眠時間: 2 消費者1消費一個數據: A4 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 5 生產者正在存第 6 個數據: A5 生產者 睡眠時間: 5 消費者2消費一個數據: A5 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 6 生產者正在存第 7 個數據: A6 生產者 睡眠時間: 7 消費者1消費一個數據: A6 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 7 生產者正在存第 8 個數據: A7 生產者 睡眠時間: 3 消費者2消費一個數據: A7 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 8 生產者正在存第 9 個數據: A8 生產者 睡眠時間: 2 消費者1消費一個數據: A8 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 4 生產者正在存第 10 個數據: A9 生產者 睡眠時間: 4 消費者2消費一個數據: A9 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 5 生產者正在存第 11 個數據: A10 生產者 睡眠時間: 2 消費者1消費一個數據: A10 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 3 生產者正在存第 12 個數據: A11 生產者 睡眠時間: 3 消費者2消費一個數據: A11 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 3 生產者正在存第 13 個數據: A12 生產者 睡眠時間: 3 消費者1消費一個數據: A12 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 3 生產者正在存第 14 個數據: A13 生產者 睡眠時間: 8 消費者2消費一個數據: A13 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 7 生產者正在存第 15 個數據: A14 生產者 睡眠時間: 3 消費者1消費一個數據: A14 消費者1檢測到隊列數量: 0 消費者1 睡眠時間: 7 生產者正在存第 16 個數據: A15 生產者 睡眠時間: 2 消費者2消費一個數據: A15 消費者2檢測到隊列數量: 0 消費者2 睡眠時間: 9 

從這個例子中,我們發現利用隊列,來做同步時非常簡單方便的,除此之外隊列,還有如下幾個方便的方法:

介紹一下此包中的常用方法:   

Queue.qsize() 返回隊列的大小  Queue.empty() 如果隊列為空,返回True,反之False  Queue.full() 如果隊列滿了,返回True,反之False Queue.full 與 maxsize 大小對應  Queue.get([block[, timeout]])獲取隊列,timeout等待時間  Queue.get_nowait() 相當Queue.get(False) 非阻塞 Queue.put(item) 寫入隊列,timeout等待時間  Queue.put_nowait(item) 相當Queue.put(item, False) Queue.task_done() 在完成一項工作之后,Queue.task_done()函數向任務已經完成的隊列發送一個信號 Queue.join() 實際上意味著等到隊列為空,再執行別的操作 

以上就是詳解Python 模擬實現生產者消費者模式的實例,如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 富川| 沙洋县| 房产| 武宣县| 丰台区| 伊吾县| 宜良县| 鹤庆县| 慈利县| 瑞安市| 广东省| 沂南县| 武陟县| 延长县| 古丈县| 望城县| 诸暨市| 福海县| 内黄县| 项城市| 治多县| 定远县| 南郑县| 奇台县| 鹤壁市| 文成县| 盱眙县| 遂溪县| 吉隆县| 奇台县| 赤水市| 柳州市| 武山县| 沈阳市| 军事| 武平县| 东安县| 北碚区| 鄢陵县| 乳山市| 磴口县|