您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
这篇文章主要介绍pyqt5中QThread在使用时出现重复emit的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
在PyQt5中使用QThread的时候,要注意把所有QThread的对象在主类中的init(或者放在所有类函数的外面)中进行实例化,不然可能在多个QThread互相调用的时候,emit重复的信号。一般比较正确的写法如下所示,基本照着这种框架搭建都是没问题的。
# -*- coding: utf-8 -*- import sys import time from 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的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。