在使用python的多线程时,使用了生产者消费者模式,一般都是消费者接受生产者的数据执行某些操作,但是现在这个消费者线程遇到了异常,需要终止执行,但是生产者线程因为还在生产数据,主线程在等待它执行完。目前想当消费者线程遇到错误时能够通知生产者线程,我挂了,你也结束吧。请问大家有什么好的实现方法
import threading
class 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 data
if data == 5:
raise ValueError('over')
except ValueError as e:
#通知生产者结束
#如何实现?
Ma méthode :
Ajouter un drapeau.
Regardons d'abord les résultats :
Fini les bêtises, montre-toi le code
Enfin, parlons du multi-threading de Python En raison de l'existence de GIL, le multi-threading n'est parfois pas le meilleur choix. Il y a beaucoup d'informations sur Internet sur quand l'utiliser. choisissez-le en fonction de sa propre situation commerciale. Obtenez le module multithreading.
Pour faire simple, déclenchez simplement l'erreur et laissez le processus planter tout seul.
Vous pouvez également utiliser la gestion des exceptions pour envelopper l'exécution du consommateur, intercepter l'exception, puis contrôler la production. Suivez simplement le fil de discussion. ci-dessous.