Python+PyQT5的子线程更新UI界面
16lz
2021-01-26
子线程里是不能更新UI界面的,在移动端方面。Android的UI访问是没有加锁的,多个线程可以同时访问更新操作同一个UI控件。也就是说访问UI的时候,android系统当中的控件都不是线程安全的,这将导致在多线程模式下,当多个线程共同访问更新操作同一个UI控件时容易发生不可控的错误。所以Android中规定只能在UI线程中访问UI,相当于从另一个角度给Android的UI访问加上锁,一个伪锁。
在PyQT5中使用QThread
from PyQt5.QtWidgets import QMainWindow, QPushButton, QApplicationfrom PyQt5.QtWidgets import *from PyQt5.QtCore import *import time#继承QThreadclass Mythread(QThread): # 定义信号,定义参数为str类型 breakSignal = pyqtSignal(int) def __init__(self, parent=None): super().__init__(parent) # 下面的初始化方法都可以,有的python版本不支持 # super(Mythread, self).__init__() def run(self): #要定义的行为,比如开始一个活动什么的 for i in(1,1000): print(i) self.breakSignal.emit(i) if __name__ == '__main__': app = QApplication([]) dlg = QDialog() dlg.resize(400, 300) dlg.setWindowTitle("自定义按钮测试") dlgLayout = QVBoxLayout() dlgLayout.setContentsMargins(40, 40, 40, 40) btn = QPushButton('测试按钮') dlgLayout.addWidget(btn) dlgLayout.addStretch(40) dlg.setLayout(dlgLayout) dlg.show() def chuli(a): # dlg.setWindowTitle(s) btn.setText(str(a)) # 创建线程 thread = Mythread() # # 注册信号处理函数 thread.breakSignal.connect(chuli) # # 启动线程 thread.start() dlg.exec_() app.exit()
在python中刷新UI可以类似,采用消息传递的机制。
可以在子线程中修改主线程的变量,主线程读取变量并绘制的方式。
更多相关文章
- 一切为了更贴近系统―Android中的线程模型
- 深入源码系列:聊聊android属性动画执行线程问题(invalidate(false
- Android(安卓)RatingBar 评星控件的自定义大小和样式
- Android(安卓)断点续传,手写多线程下载文件、数据库存储进度
- Android(安卓)Watchdog(看门狗)分析
- Android(安卓)自定义控件之组合控件
- Android(安卓)中的线程形态 -- AsyncTask,HandlerThread,IntentSer
- android中的通信机制总结1:使用handler来进行通信
- Android----xml文件中的控件的id设置