av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

python中生產(chǎn)者消費(fèi)者線程問題

瀏覽:132日期:2022-08-25 14:16:33

問題描述

在使用python的多線程時,使用了生產(chǎn)者消費(fèi)者模式,一般都是消費(fèi)者接受生產(chǎn)者的數(shù)據(jù)執(zhí)行某些操作,但是現(xiàn)在這個消費(fèi)者線程遇到了異常,需要終止執(zhí)行,但是生產(chǎn)者線程因為還在生產(chǎn)數(shù)據(jù),主線程在等待它執(zhí)行完。目前想當(dāng)消費(fèi)者線程遇到錯誤時能夠通知生產(chǎn)者線程,我掛了,你也結(jié)束吧。請問大家有什么好的實現(xiàn)方法

import threadingclass Producer(threading.Thread): def __init__(self, queue):super(Producer, self).__init__()self.queue = queue def run(self):while True: for i in range(10):self.queue.put(i)class Consumer(threading.Thread): def __init__(self, queue):super(Consumer, self).__init__()self.queue = queue def run(self):while True: try:data = self.queue.get()print dataif data == 5: raise ValueError(’over’) except ValueError as e:#通知生產(chǎn)者結(jié)束#如何實現(xiàn)?

問題解答

回答1:

我的方法:添加一個 flag 標(biāo)識。

先看結(jié)果吧:

python中生產(chǎn)者消費(fèi)者線程問題

更多廢話也不多說了,show u the code

#!/usr/bin/python# coding=utf-8import threadingimport timeclass Producer(threading.Thread): def __init__(self, queue, flag):super(Producer, self).__init__()self.queue = queueself.flag = flag def run(self):while True: length = max(self.queue) + 1 print '============================= producer queue', self.queue self.queue.append(length) print ’flag length=’, len(self.flag) if len(self.flag) == 0:print 'producer 我也結(jié)束了'break time.sleep(2)class Consumer(threading.Thread): def __init__(self, queue, flag):super(Consumer, self).__init__()self.queue = queueself.flag = flag def run(self):while True: try:length = len(self.queue)print 'consumer queue', self.queueif length > 5: self.flag.pop() # 注意我是flag raise ValueError(’over’)self.queue.pop(0) except ValueError as e:# 通知生產(chǎn)者結(jié)束# 如何實現(xiàn)?print 'consumer 我結(jié)束了', ebreak# raise(e) time.sleep(4)queue = [1, 2, 3]flag = [0] # 表示正常Consumer(queue, flag).start()time.sleep(1)Producer(queue, flag).start()

最后說說python的多線程,由于GIL的存在,其實多線程有的時候并不是最好的選擇,具體什么時候使用,網(wǎng)上也說的很多了,樓主也可以結(jié)合自己的業(yè)務(wù)情況舍取多線程模塊。

回答2:

簡單的話,就直接把錯誤raise出來,然后讓進(jìn)程自己崩潰掉就好了.或者,你也可以用異常處理把消費(fèi)者的run包裹起來,捕獲這個異常,然后再控制生產(chǎn)者的線程就好了.

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 欧美mv日韩mv国产网站91进入 | 国产精品成人在线 | 欧洲亚洲一区二区三区 | 色噜噜狠狠色综合中国 | 色视频成人在线观看免 | 狠狠入ady亚洲精品经典电影 | 日韩中文字幕一区二区 | 性高湖久久久久久久久3小时 | 欧产日产国产精品国产 | 国产一区二区激情视频 | 成人亚洲综合 | 日韩欧美视频在线 | 亚洲国产精品一区二区三区 | 黄色大片网站 | 国产免费一区二区三区 | 日韩欧美中文字幕在线观看 | 国产成人精品一区二区三区在线 | 精品久久久av | 一区二区三区中文 | 九九九视频在线观看 | 美女黄色在线观看 | 蜜桃在线一区二区三区 | 免费人成在线观看网站 | 亚洲性视频 | 精品视频在线观看 | 国产一区二区高清在线 | 日韩欧美网 | 国产精品日本一区二区在线播放 | 国产成人精品一区二 | 国产丝袜一区二区三区免费视频 | 久久久成人免费一区二区 | 亚洲精品www久久久久久广东 | 欧美日韩黄色一级片 | 国产精品一二三区在线观看 | 99精品欧美一区二区蜜桃免费 | 成人免费在线视频 | 国产精品99999999 | 在线国产小视频 | 一区二区三区精品在线视频 | 免费a v网站 | 国产激情视频 |