子线程里是不能更新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 #继承QThread class 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可以类似,采用消息传递的机制。

可以在子线程中修改主线程的变量,主线程读取变量并绘制的方式。

以上这篇Python+PyQT5的子线程更新UI界面的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

更多相关文章

  1. 修改Android中Spinner的显示及下拉样式的四种方法
  2. 第三部分:Android(安卓)应用程序接口指南---第二节:UI---第二章 输
  3. Android实现定时器的几种方法
  4. 自定义View 篇一--------《自定义View流程分析》
  5. android一些常用基础UI控件(比较适合给新手参考)
  6. Android(安卓)中UI与耗时操作的分离
  7. 关于android多任务同时下载的一点心得
  8. android中自定义控件之TitleBar实现
  9. 使用Android(安卓)AsyncTask异步线程

随机推荐

  1. android反编译工具(ApkDec-Release-0.1)-正
  2. Android 译文:Android中糟糕的AsyncTask
  3. 【Android(安卓)XML】Android(安卓)XML
  4. Android 运行底层linux外部命令的实现
  5. android AsyncTask学习
  6. Android APK反编译查看源码及资源文件
  7. Android 屏幕横竖切换详解
  8. android 按键
  9. android 圆角效果
  10. Android 屏幕切换和onConfigurationChang