python 继承线程的类 不能通过标志位结束线程
问题描述
在测试生产消费者模型的时候遇到这样一个问题,在继承线程后 加了个标志位 mark
class Consumer(threading.Thread): def __init__(self, queue):threading.Thread.__init__(self)self._queue = queueself.mark = True def run(self):while self.mark: msg = self._queue.get() if isinstance(msg, str) and msg == ’quit’:break print('I’m a thread, and I received %s!!' % msg)print(’Bye byes!’)
def producer(): q = queue.Queue() worker = Consumer(q) worker.start() # 开启消费者线程 start_time = time.time() while time.time() - start_time < 5:q.put(’something at %s’ % time.time())time.sleep(1) worker.mark = Flese worker.join()
我原先指望 通过这个标志位来实现线程的结束控制,但实际效果是程序卡死在worker.join()完全没有退出。
请教下,这是什么原因?
问题解答
回答1:class Consumer(threading.Thread): def __init__(self, queue):threading.Thread.__init__(self)self._queue = queueself.mark = True def run(self):while self.mark: try:msg = self._queue.get(block=False) # 非阻塞print('I’m a thread, and I received %s!!' % msg) except:pass print(’self.mark’,self.mark)print(’Bye byes!’)def producer(): q = queue.Queue() worker = Consumer(q) worker.start() # 开启消费者线程 start_time = time.time() while time.time() - start_time < 5:q.put(’something at %s’ % time.time())time.sleep(1) worker.mark = False worker.join()
相关文章:
1. docker-machine添加一个已有的docker主机问题2. java-ee - JAVA的注解@Api和@ApiOperation的作用是什么,怎么跳转页面的3. java - mybatis会自己缓存自己生成过的prestatement吗4. java - 原生CGLib内部方法互相调用时可以代理,但基于CGLib的Spring AOP却代理失效,为什么?5. java - tomcat服务经常晚上会挂,求解?6. node.js - node express 中ajax post请求参数接收不到?7. apache - nginx 日志删除后 重新建一个文件 就打不了日志了8. 怎么能做出标签切换页的效果,(文字内容随动)9. mysql - mongo如何对一个collection进行顺序上的调整呢?10. chrome浏览器怎么使用
