pyqt5中QThread在使用时出现重复emit的实例
Python  /  管理员 发布于 5年前   518
在PyQt5中使用QThread的时候,要注意把所有QThread的对象在主类中的init(或者放在所有类函数的外面)中进行实例化,不然可能在多个QThread互相调用的时候,emit重复的信号。一般比较正确的写法如下所示,基本照着这种框架搭建都是没问题的。
# -*- coding: utf-8 -*-import sysimport timefrom PyQt5.QtWidgets import *from PyQt5.QtCore import * class MainUi(QWidget): def __init__(self): super(MainUi, self).__init__() self.resize(400, 200) self.setWindowTitle('QThread例子') # 实例化多线程对象 self.thread = Worker() # 实例化列表控件与按钮控件 self.listFile = QListWidget() self.btnStart = QPushButton('开始') self.btn_over = QPushButton('结束') # 把控件放置在栅格布局中 layout = QGridLayout(self) layout.addWidget(self.listFile, 0, 0, 1, 2) layout.addWidget(self.btnStart, 1, 0) layout.addWidget(self.btn_over, 1, 1) # 信号与槽函数的连接 self.btnStart.clicked.connect(self.slotStart) self.btn_over.clicked.connect(self.slot_btn_over) # 建立线程信号的槽连接 self.thread.trigger.connect(self.slotAdd) def slotAdd(self, msg): print(msg) if int(msg) % 2 == 0: self.listFile.addItem(msg) else: pass self.thread.exit() def slotStart(self): self.btnStart.setEnabled(False) self.thread.start() def slot_btn_over(self): self.btnStart.setEnabled(True) self.thread.terminate() self.thread.num = 0 class Worker(QThread): trigger = pyqtSignal(str) num = 0 def __init__(self): super(Worker, self).__init__() def run(self): while True: print('num= ', self.num) if self.num % 2 == 0: self.trigger.emit(str(50)) elif self.num == 200: self.num = 0 else: pass time.sleep(0.1) self.num += 1 if __name__ == '__main__': app = QApplication(sys.argv) w = MainUi() w.show() sys.exit(app.exec_())
以上这篇pyqt5中QThread在使用时出现重复emit的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号