PySide6之多线程
一、QThread
方法1:子类化创建多线程
- 创建子线程,继承自QThread类
- 在子线程中自定义信号
- 在子线程中重写 run() 方法,进行信号的触发
- 在主线程中实例化子线程
- 在主线程中对子线程的信号进行绑定
- 在主线程中开启子线程
import time
from PySide6.QtCore import *
from PySide6.QtWidgets import *
# s1. 子线程类:继承自QThread
class WorkThread(QThread):
# s2. 自定义信号
signal = Signal(str)
def __init__(self):
super().__init__()
# 重写 run() 方法
def run(self):
for i in range(10):
time.sleep(1)
# s3. 信号触发
self.signal.emit(str(i)) # 发送信号
# 主线程
class MainWindow(QWidget):
def __init__(self):
super().__init__()
# 创建一个标签,用于显示子线程的信号
self.label = QLabel()
# s4. 实例化子线程
self.workThread = WorkThread() # 用self实例化,防止子线程被回收
# s5. 对子线程的信号进行绑定
self.workThread.signal.connect(lambda x: self.label.setText(f"当前的值为:{x}")) # 将信号连接到标签
self.workThread.started.connect(lambda: self.label.setText("子线程开启")) # 子线程开启时激活
self.workThread.finished.connect(lambda: self.label.setText("子线程关闭")) # 子线程结束时激活
self.workThread.finished.connect(lambda: self.workThread.deleteLater()) # 释放子线程
# s6. 开启子线程
self.workThread.start()
# 布局
self.mainLayout = QVBoxLayout()
self.mainLayout.addWidget(self.label)
self.setLayout(self.mainLayout)
if __name__ == "__main__":
app = QApplication([])
window = MainWindow()
window.show()
app.exec()
方法2:实例化创建多线程
- 在子线程中自定义信号
- 在子线程中进行信号的触发
- 在主线程中实例化子线程
- 在主线程中实例化QThread类
- 在主线程中将子线程用
moveToThread()方法绑定到QThread - 在主线程中对子线程的信号进行绑定
- 在主线程中,QThread开始时调用子线程类中的方法
- 在主线程中开启子线程
import time
from PySide6.QtCore import *
from PySide6.QtWidgets import *
# 子线程类
class WorkThread(QObject):
# s1. 自定义信号
signal = Signal(str)
def __init__(self):
super().__init__()
def runFunction(self):
for i in range(10):
# s2. 信号触发
self.signal.emit(str(i)) # 发送信号
time.sleep(1)
# 主线程
class MainWindow(QWidget):
def __init__(self):
super().__init__()
# 创建一个标签,用于显示子线程的信号
self.label = QLabel()
# s3. 实例化子线程
self.workThread = WorkThread() # 用self实例化,防止子线程被回收
# s4. 实例化QThread类
self.thread = QThread()
# s5. 将子线程绑定到QThread
self.workThread.moveToThread(self.thread)
# s6. 对子线程的信号进行绑定
self.workThread.signal.connect(lambda x: self.label.setText(f"当前的值为:{x}")) # 将信号连接到标签
# s7. QThread开始时,调用子线程类中的方法
self.thread.started.connect(self.workThread.runFunction)
# QThread结束时激活
self.thread.finished.connect(lambda: print("Finished"))
# s8. 开启子线程
self.thread.start()
# 布局
self.mainLayout = QVBoxLayout()
self.mainLayout.addWidget(self.label)
self.setLayout(self.mainLayout)
if __name__ == "__main__":
app = QApplication([])
window = MainWindow()
window.show()
app.exec()
二、主线程向子线程传递信号
在子线程的 __init__() 方法中设置形参,在主线程实例化子线程时传入消息。
import time
from PySide6.QtCore import *
from PySide6.QtWidgets import *
# 子线程类:继承自QThread类
class WorkThread(QThread):
# 自定义信号
signal = Signal(str)
# 在 __init__() 方法中接收主线程的信号
def __init__(self, message):
super().__init__()
self.message = message
# 重写 run() 方法
def run(self):
# 子线程向主线程发送信号
self.signal.emit(f"子线程接收到信息:{self.message}")
# 主线程
class MainWindow(QWidget):
def __init__(self):
super().__init__()
# 创建一个标签,用于显示子线程的信号
self.label = QLabel()
# 实例化子线程,并传入发送给子线程的消息
self.workThread = WorkThread("这是主线程发给子线程的信息!")
# 对子线程的信号进行绑定
self.workThread.signal.connect(lambda message: self.label.setText(message))
# 开启子线程
self.workThread.start()
# 布局
self.mainLayout = QVBoxLayout()
self.mainLayout.addWidget(self.label)
self.setLayout(self.mainLayout)
if __name__ == "__main__":
app = QApplication([])
window = MainWindow()
window.show()
app.exec()
三、多线程的阻塞和删除(释放)
多线程的阻塞:
在主线程中,调用子线程实例化对象的 wait() 方法,可以对子线程进行阻塞,直到子线程方法运行结束或返回值,才继续运行。如:
self.workThread.wait()
多线程的删除(释放):
在主线程中,调用子线程实例化对象的 deleteLater() 方法,可以对子线程进行删除,该方法通常和子线程对象的 finished() 配合使用,用于在子线程执行完成后释放内存。如:
self.workThread.finished.connect(lambda: self.workThread.deleteLater())
PySide6之多线程的更多相关文章
- Python中的多进程与多线程(一)
一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...
- 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例
前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...
- 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)
前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...
- Java多线程
一:进程与线程 概述:几乎任何的操作系统都支持运行多个任务,通常一个任务就是一个程序,而一个程序就是一个进程.当一个进程运行时,内部可能包括多个顺序执行流,每个顺序执行流就是一个线程. 进程:进程 ...
- .NET基础拾遗(5)多线程开发基础
Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理基础 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开 ...
- Java多线程基础——对象及变量并发访问
在开发多线程程序时,如果每个多线程处理的事情都不一样,每个线程都互不相关,这样开发的过程就非常轻松.但是很多时候,多线程程序是需要同时访问同一个对象,或者变量的.这样,一个对象同时被多个线程访问,会出 ...
- C#多线程之线程池篇3
在上一篇C#多线程之线程池篇2中,我们主要学习了线程池和并行度以及如何实现取消选项的相关知识.在这一篇中,我们主要学习如何使用等待句柄和超时.使用计时器和使用BackgroundWorker组件的相关 ...
- C#多线程之线程池篇2
在上一篇C#多线程之线程池篇1中,我们主要学习了如何在线程池中调用委托以及如何在线程池中执行异步操作,在这篇中,我们将学习线程池和并行度.实现取消选项的相关知识. 三.线程池和并行度 在这一小节中,我 ...
- C#多线程之线程池篇1
在C#多线程之线程池篇中,我们将学习多线程访问共享资源的一些通用的技术,我们将学习到以下知识点: 在线程池中调用委托 在线程池中执行异步操作 线程池和并行度 实现取消选项 使用等待句柄和超时 使用计时 ...
- C#多线程之线程同步篇3
在上一篇C#多线程之线程同步篇2中,我们主要学习了AutoResetEvent构造.ManualResetEventSlim构造和CountdownEvent构造,在这一篇中,我们将学习Barrier ...
随机推荐
- Mybatis学习五($和#区别以及其他tips)
1.$和#区别 1 #是将传入的值当做字符串的形式,eg:select id,name,age from student where id =#{id},当前端把id值1,传入到后台的时候,就相当于 ...
- .NET CORE 完美支持AOT 的 ORM SqlSugar 教程
1.AOT适合产场 Aot适合工具类型的项目使用,优点禁止反编 ,第一次启动快,业务型项目或者反射多的项目不适合用AOT AOT更新记录: 实实在在经过实践的AOT ORM 5.1.4.117 +支持 ...
- 【YoloDeployCsharp】基于.NET Framework的YOLO深度学习模型部署测试平台
1. 项目介绍 基于.NET Framework 4.8 开发的深度学习模型部署测试平台,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det.Seg.Pose.Obb ...
- 使用DP-Modeler、ModelFun模方软件修复实景三维模型教程
P-Modeler DP-Modeler是武汉天际航自主研发的一款集精细化单体建模与Mesh网格模型修饰于一体的软件.支持三维模型一键水面修复.道路置平.建筑局部修饰.删除底部碎片.植被处理.桥隧 ...
- UE4/5 应用角色根运动的问题
总的来说UE还是有点绕,网上提到的也不是很清晰,记录下. 具体可以下载UE官方示例ContentExample并进入Animation Level进行查看. 在Level中能看到根运动的必要步骤: 1 ...
- 推荐几款火爆的Python在线编辑器
在当今数字化时代,编程已成为一项不可或缺的技能.Python作为一种简单易学且功能强大的编程语言,受到了广大编程爱好者和专业开发人员的青睐.为了方便大家随时随地编写和运行Python代码,市面上涌现了 ...
- springboot使controller异步调用
调用controller方法,遇到操作时间很长的情况下,不希望前端一直等待操作,而希望前端立马接收到操作启动的反馈,而真正的操作在后端执行,需要用到异步调用的方法.实现步骤如下: 一.配置异步支持: ...
- 数据分析---numpy模块
前戏 NumPy(Numerical Python) 是 Python 语言中做科学计算的基础库.重在于数值计算,也是大部分Python科学计算库的基础,多用于在大型.多维数组上执行的数值运算. 快捷 ...
- ABP邮件发送
ABP Vnext发邮件要使用AbpMailKitModule的实现IEmailSender,要检查添加了Volo.Abp.MailKit,其dependon 要添加typeof() 它使用Sett ...
- AppFlow上新——智谱ChatGLM轻松接入聊天
智谱AI 开放平台提供一系列具有不同功能和定价的大模型,包括通用大模型.超拟人大模型.图像大模型.向量大模型等,并且支持使用您的私有数据对模型进行微调.其中ChatGLM系列模型在国内也享有盛名,现在 ...