Qt::浅谈信号槽连接,参数在多线程中的使用

Qt的信号槽有五种连接方式定义在enum Qt::ConnectionType,下面简单介绍

Qt::AutoConnection:自动判断连接方式,如果信号发送对象和执行槽对象在同一线程,那么等于Qt::DirectConnection,如果不是则等于Qt::QueuedConnection

Qt::DirectConnection:直接连接方式,简单说就是直接调用,信号发送会在槽函数执行完毕后返回,但前提是信号和槽的对象必须在同一线程中,否则会出现未知错误

Qt::QueuedConnection:队列连接方式,信号的发送是通知当前线程事件机制增加一个待处理事件,槽的执行不一定能马上返回,发送信号马上返回,两者是异步执行,主要是为了解决信号和槽对象不在同一线程不阻塞的情况

Qt::BlockingQueuedConnection:阻塞队列连接方式,逻辑基本和前者相同,唯一的区别是,发送信号不会马上返回,一定会等到槽执行完毕返回后,才返回信号调用,对于需要阻塞等到返回值结果的时候,可以使用

Qt::UniqueConnection:独立连接方式,这个标识比较少用,可以和上面4个标识做OR运算表示这个连接对象为单例,如果有一样的对象信号绑定了一样的槽,绑定动作会返回失败

单线程的情况没什么好说,第二种方式直接的调用,主要说一下多线程的情况

写UI的同学应该都有使用过以下回调函数,这是因为在qt里子线程不能操作UI相关的对象接口,必须要把事件和动作交给主线程处理

那么一般就会有两种情况,阻塞和非阻塞式;阻塞式就是必须要等到这次动作的返回值才能往下执行,如果以第三种连接方式,即使加上了QGenericReturnArgument也无效,就需要选择第四种连接方式

但是Qt::BlockingQueuedConnection在子线程不受你控制或者不在你自己的代码里的时候,容易发生死锁,比如一个主线程调用子线程的某方法,在这个方法里又发送了信号交给主线程处理事件,由于子线程一直等待主线程处理完事件返回继续往下,但主线程又卡在了调用子线程方法的地方,导致二者直接死锁,所以这个连接方式要慎用,至少你要明白引发这种连接信号一系列的调用关系再来确认怎么处理;另外还有一种情况需要block,那就是参数中有指针的情况,如果这个指针的指向对象是临时变量,当非阻塞方式交出去的时候,可能对象已经析构回收掉了,那么调用参数会访问一个野指针,所以要么拷贝一份指针数据到可靠的地方(至少确认执行的时候数据还在),要么就得用阻塞方式,等待处理结束后,再释放指针指向对象。

Demo代码待续,主要会列举一下几种方式的正常调用写法

原文地址:https://www.cnblogs.com/KaiMing-Prince/p/8715840.html

时间: 2024-08-28 14:27:00

Qt::浅谈信号槽连接,参数在多线程中的使用的相关文章

Qt浅谈之十六:TCP和UDP(之一)

一.简介 Qt使用QtNetwork模块来进行网络编程,提供了一层统一的套接字抽象用于编写不同层次的网络程序,避免了应用套接字进行网络编的繁琐(因有时需引用底层操作系统的相关数据结构).有较底层次的类如QTcpSocket.QTcpServer和QUdpSocket等来表示低层的网络概念:还有高层次的类如QNetworkRequest.QNetworkReply和QNetworkAccessManager使用相同的协议来执行网络操作:也提供了QNetworkConfiguration.QNetw

Qt浅谈内存泄露(总结)

Qt浅谈内存泄露(总结) 来源 http://blog.csdn.net/taiyang1987912/article/details/29271549 一.简介 Qt内存管理机制:Qt 在内部能够维护对象的层次结构.对于可视元素,这种层次结构就是子组件与父组件的关系:对于非可视元素,则是一个对象与另一个对象的从属关系.在 Qt 中,在 Qt 中,删除父对象会将其子对象一起删除. C++中delete 和 new 必须配对使用(一 一对应):delete少了,则内存泄露,多了麻烦更大.Qt中使用

Core Data浅谈系列之十 : 关于数据模型中实体的属性

之前写了<Core Data浅谈系列汇总>,今天稍微回顾了下,做些补充. 在这个系列的第一篇<基础结构>中(2013年1月份的文章,时间过得好快啊!),有简单带过Entity的Attribute: 数据类型.布尔值统一用NSNumber来表示: 字符串类型用NSString表示: 时间类型用NSDate表示: 二进制数据类型用NSData表示: 非标准类型用Transformable来表示: 而Attribute还有其自身的Properties,比如Transient表示不用持久化

浅谈分词算法(1)分词中的基本问题

[TOC] 前言 分词或说切词是自然语言处理中一个经典且基础的问题,在平时的工作中也反复的接触到分词问题,用到了不同的模型,不同的方法应用在各个领域中,所以想对分词问题做一个系统的梳理.大多数分词问题主要是针对类似汉语.韩语.日语等,词语之间并没有天然的分割,而像英语等,句子中是带有天然的分割的.但是英语也会涉及到分词问题,比如实体识别.词性标注等内容.而本系列文章更多的是讨论汉语中的分词问题,首先我们从分词问题的基本出发,之后从传统的词典分词到将分词转为序列标注问题的分词,以及最新的结合深度学

Qt之信号槽连接——基于字符串与基于函数的连接之间的不同(译)

从Qt5.0开始,Qt提供了两种不同的方式进行信号槽的连接:基于字符串的连接语法.基于函数的连接语法.这两种连接语法各有利弊,下面的表总结了它们的不同点. 下面几部分详细解释了它们之间的不同,并且说明对于每种连接语法如何使用各自的优点. 类型检查以及隐式类型转换 基于字符串的连接是在运行时通过字符串比较来进行类型检查,这种方式有3个局限性: 1.只有在程序运行后才能查出连接错误: 2.信号和槽之间不能进行隐式转换: 3.类型定义和名字空间不能被识别. 第2第3个局限存在的原因是,字符串的比较并不

Qt开发之信号槽机制

一.信号槽机制原理 1.如何声明信号槽 Qt头文件中一段的简化版: class Example: public QObject { Q_OBJECT signals: void customSignal(); void customSignal(int i) public slots: void customSlot(); void customSlot(int i); }; 2.宏与MOC源对象 摘录代码: // qobjectdefs.h i. … ii. #define slots iii

Linux系统编程之进程间通信之浅谈信号

我们接着谈Linux学习过程中一个重要的话题--信号. 一.信号的概念:       信号是一种软件中断,它提供了一种处理异步事件的方法,也是进程间唯一的异步通信方式.二.信号的来源:       1.硬件方式:             当用户按下终端上某些键时,将产生信号.             硬件异常产生信号:除0操作.访问非法空间--       2.软件方式             用户在终端下调用kill命令向进程发送任意信号        进程调用kill或者sigqueue函数

Qt浅谈之二十七进程间通信之QtDBus

一.简介 DBus的出现,使得Linux进程间通信更加便捷,不仅可以和用户空间应用程序进行通信,而且还可以和内核的程序进行通信,DBus使得Linux变得更加智能,更加具有交互性.        DBus分为两种类型:system bus(系统总线),用于系统(Linux)和用户程序之间进行通信和消息的传递:session bus(回话总线),用于桌面(GNOME, KDE等)用户程序之间进行通信. 二.详解之Qt代码 1.代码一 (1)test.h [html] view plain copy

Qt浅谈之二十App自动重启及关闭子窗口(六种方法)

一.简介 最近因项目需求,Qt程序一旦检测到错误,要重新启动,自己是每次关闭主窗口的所有子窗口但有些模态框会出现问题,因此从网上总结了一些知识点,以备以后的应用. 二.详解 1.Qt结构 [cpp] view plaincopy int main(int argc, char *argv[]) { QApplication a(argc, argv); MyWidget w; MyDialog dialog;                      //新建MyDialog类对象 if(dia