一、QThread

方法1:子类化创建多线程

  1. 创建子线程,继承自QThread类
  2. 在子线程中自定义信号
  3. 在子线程中重写 run() 方法,进行信号的触发
  4. 在主线程中实例化子线程
  5. 在主线程中对子线程的信号进行绑定
  6. 在主线程中开启子线程
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:实例化创建多线程

  1. 在子线程中自定义信号
  2. 在子线程中进行信号的触发
  3. 在主线程中实例化子线程
  4. 在主线程中实例化QThread类
  5. 在主线程中将子线程用 moveToThread() 方法绑定到QThread
  6. 在主线程中对子线程的信号进行绑定
  7. 在主线程中,QThread开始时调用子线程类中的方法
  8. 在主线程中开启子线程
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之多线程的更多相关文章

  1. Python中的多进程与多线程(一)

    一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...

  2. 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例

    前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...

  3. 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)

    前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...

  4. Java多线程

    一:进程与线程 概述:几乎任何的操作系统都支持运行多个任务,通常一个任务就是一个程序,而一个程序就是一个进程.当一个进程运行时,内部可能包括多个顺序执行流,每个顺序执行流就是一个线程.   进程:进程 ...

  5. .NET基础拾遗(5)多线程开发基础

    Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理基础 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开 ...

  6. Java多线程基础——对象及变量并发访问

    在开发多线程程序时,如果每个多线程处理的事情都不一样,每个线程都互不相关,这样开发的过程就非常轻松.但是很多时候,多线程程序是需要同时访问同一个对象,或者变量的.这样,一个对象同时被多个线程访问,会出 ...

  7. C#多线程之线程池篇3

    在上一篇C#多线程之线程池篇2中,我们主要学习了线程池和并行度以及如何实现取消选项的相关知识.在这一篇中,我们主要学习如何使用等待句柄和超时.使用计时器和使用BackgroundWorker组件的相关 ...

  8. C#多线程之线程池篇2

    在上一篇C#多线程之线程池篇1中,我们主要学习了如何在线程池中调用委托以及如何在线程池中执行异步操作,在这篇中,我们将学习线程池和并行度.实现取消选项的相关知识. 三.线程池和并行度 在这一小节中,我 ...

  9. C#多线程之线程池篇1

    在C#多线程之线程池篇中,我们将学习多线程访问共享资源的一些通用的技术,我们将学习到以下知识点: 在线程池中调用委托 在线程池中执行异步操作 线程池和并行度 实现取消选项 使用等待句柄和超时 使用计时 ...

  10. C#多线程之线程同步篇3

    在上一篇C#多线程之线程同步篇2中,我们主要学习了AutoResetEvent构造.ManualResetEventSlim构造和CountdownEvent构造,在这一篇中,我们将学习Barrier ...

随机推荐

  1. Django高级表单处理与验证实战

    title: Django高级表单处理与验证实战 date: 2024/5/6 20:47:15 updated: 2024/5/6 20:47:15 categories: 后端开发 tags: D ...

  2. CINN 中子图编译缓存机制

    采用 「问-答」形式记录研读 CINN 开源框架的笔记 Q:CINN中子图编译的入口是在哪里? for (const auto& node_vec : clusters) { // <- ...

  3. 2019年最新前端面试题,js程序设计题

    都说机会是留给有准备的人的. 一年之计在于春,面对众多的前端技术,需要时刻充电自己. 我现在整理一些前端js面试程序题. 1.判断一个字符串中出现最多的字符,并计算出现的次数? 2.用css伪类实现下 ...

  4. CentOS7离线部署JDK

    一. 下载JDK 官网地址: https://www.oracle.com/java/technologies/downloads/#java18 网盘地址: 链接:https://pan.baidu ...

  5. C# 炸弹人 winform版

    实现这个游戏的基本功能包含几个对象:玩家,怪物,墙砖,炸弹,通关的门.玩家通过上下左右方向键移动,放置炸弹,被怪物杀死,被炸弹炸死.怪物随机方向移动,能杀死玩家.炸弹有爆炸功能,炸弹的火花长度.通过的 ...

  6. KPM算法求字符串的最小周期证明

    先给出公式 ans = n - LPS[n-1] 其中ans为最小周期,n为给出的由假设的周期字符串中提取出的子串长度,LPS为前缀函数,n-1为字符串最后的位置下标 证明如下 证明ans = n - ...

  7. Django——messages消息框架

    在网页应用中,我们经常需要在处理完表单或其它类型的用户输入后,显示一个通知信息给用户.对于这个需求,Django提供了基于Cookie或者会话的消息框架messages,无论是匿名用户还是认证的用户. ...

  8. 《最新出炉》系列入门篇-Python+Playwright自动化测试-49-Route类拦截修改请求-下篇

    1.简介 在日常工作和学习中,自动化测试的时候:在加载页面时,可能页面出现很多不是很重要或者不是我们所关注的,这个时候我们就可以选择不加载这些内容,以提高页面加载速度,节省资源.例如:可能页面上图片比 ...

  9. 神经网络常见参数解释:epoch、batch、batch size、step、iteration

      本文介绍在机器学习.深度学习的神经网络模型中,epoch.batch.batch size.step与iteration等名词的具体含义.   epoch:表示将训练数据集中的所有样本都过一遍(且 ...

  10. lodash已死?radash库方法介绍及源码解析 —— 随机方法 + 字符串篇

    前言 大家好,我是阿瓜.一个励志想成为艾弗森的前端瓜 ~ 我们已经分享了 radash 库中数组.对象等相关的方法,大家感兴趣的可以前往主页查看阅读: 或许你最近在某个地方听过或者看过 radash ...