中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python之生產者消費者模型實現詳解

發布時間:2020-09-04 23:28:58 來源:腳本之家 閱讀:115 作者:bainianminguo 欄目:開發技術

代碼及注釋如下

#Auther Bob
#--*--conding:utf-8 --*--
#生產者消費者模型,這里的例子是這樣的,有一個廚師在做包子,有一個顧客在吃包子,有一個服務員在儲存包子,這個服務員我們就可以用queue來實現
import threading
import queue
import time
 
'''
def consumer(p,que):
  id = que.get()
  print("[%s]來吃包子了,我吃到的包子的名字是[%s]" %(p,id))
 
def prodcer(p,que):
  print("[%s]做了2個包子" %(p))
  que.put("baozi[1]")
  print("baozi[1]做好了")
  que.put("baozi[2]")
  print("baozi[2]做好了")
 
if __name__ == '__main__':
  que = queue.Queue()
  p = threading.Thread(target=prodcer,args=("Bob",que))
  c1 = threading.Thread(target=consumer,args=("c1",que))
  c2 = threading.Thread(target=consumer, args=("c2", que))
  c3 = threading.Thread(target=consumer, args=("c3", que))
  p.start()
  c1.start()
  c2.start()
  c3.start()
  # p.join()
 
 
'''
 
 
#上面這個例子,如果沒有包子了,但是廚師會不知道,廚師也不會繼續做包子,而沒有吃到包子的人會一直等待,程序會一直不結束
 
 
 
#我們可以這樣做,消費者發現沒有包子了,告訴服務員,服務員在告訴廚師,這里我們就會遇到task.down
 
def consumer(p):
  id = que.get()
  print("[%s]來吃包子了,我吃到的包子的名字是[%s]" %(p,id))
  que.task_done()  #如歸隊列為空了,則會通知que.join,que.join就不會阻塞了
 
"""
 
def prodcer(p):
  while True:
    if que.qsize() < 3:
      # time.sleep(1)
      for i in range(2):
        print("[%s]做了包子[%d]" %(p,i))
        que.put(i)
      que.join() #如果隊列一直不為空,則que.join會一直阻塞,如果隊列為空,則que.join就不阻塞了
"""
def prodcer(p):
  while True:
    # time.sleep(1)
    for i in range(2):
      print("[%s]做了包子[%d]" %(p,i))
      que.put(i)
    que.join() #如果隊列一直不為空,則que.join會一直阻塞,如果隊列為空,則que.join就不阻塞了
if __name__ == '__main__':
  que = queue.Queue()
  p = threading.Thread(target=prodcer,args=("Bob1",))
  p2 = threading.Thread(target=prodcer, args=("Bob2",))
  c1 = threading.Thread(target=consumer,args=("c1",))
  c2 = threading.Thread(target=consumer, args=("c2",))
  c3 = threading.Thread(target=consumer, args=("c3",))
  c4 = threading.Thread(target=consumer, args=("c4",))
  c5 = threading.Thread(target=consumer, args=("c5",))
  c6 = threading.Thread(target=consumer, args=("c6",))
  p.start()
  p2.start()
  c1.start()
  c2.start()
  c3.start()
  c4.start()
  c5.start()
  c6.start()
  # p.join()
  # que.task_done()

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

比如县| 清苑县| 东明县| 仙居县| 新疆| 榆中县| 光山县| 安乡县| 蓬溪县| 剑阁县| 商丘市| 巴东县| 农安县| 寿阳县| 东乡| 焦作市| 黄骅市| 留坝县| 怀宁县| 岳普湖县| 石阡县| 凤阳县| 宜阳县| 崇文区| 渭南市| 阿荣旗| 鱼台县| 弥勒县| 麟游县| 务川| 岢岚县| 锦州市| 阜南县| 井冈山市| 丹棱县| 乐都县| 自贡市| 三台县| 明溪县| 穆棱市| 镇原县|