news 2026/6/10 2:03:53

Qt------信号槽,属性,对象树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Qt------信号槽,属性,对象树

目录

  • 1,信号槽
    • 1.1,槽函数执行顺序
    • 1.2,获取信号发出者
    • 1.3,断开连接
    • 1.4,QSignalMapper 用法

1,信号槽

1.1,槽函数执行顺序

1,槽函数执行顺序

connect(this,SIGNAL(downloadFile()),this,SLOT(onDownloadFile())); emit downloadFile(); renameFile();

看上述代码,现在有这样的一个问题,当我用 emit 发出信号后,我是执行完槽函数之后再执行renameFile函数呢,还是发出信号后立即就执行renameFile函数呢?
答案是会先执行完槽函数之后,再执行后面的函数,并不是两者并发执行。

2,信号与多个槽同时连接,槽函数的执行顺序

connect(this,SIGNAL(downloadFile()),this,SLOT(onDownloadFile2())); connect(this,SIGNAL(downloadFile()),this,SLOT(onDownloadFile3())); connect(this,SIGNAL(downloadFile()),this,SLOT(onDownloadFile1())); emit downloadFile();

当一个信号和多个槽函数连接之后,执行顺序是什么样的呢?
上述代码的执行顺序为 onDownloadFile2() , onDownloadFile3() , onDownloadFile1()。
所以当一个信号连接多个槽函数时,执行顺序就是connect的顺序

1.2,获取信号发出者

在槽函数中 利用sender() 可以获取信号发出者。

void Widget::on_pushButton_clicked() { QPushButton* btn = dynamic_cast<QPushButton*>(sender()); qDebug()<<btn->text(); }

1.3,断开连接

disconnect();
在 Qt 中,disconnect函数用于断开信号与槽之间的连接,以阻止信号发射时调用相应的槽函数。disconnect函数有多种重载形式,以下是常见的使用方式:
1. 断开特定对象的特定信号与特定槽的连接
cpp

// 假设我们有两个对象,senderObject发送信号,receiverObject接收信号并执行槽函数 QObject *senderObject = new QObject(); QObject *receiverObject = new QObject(); // 连接信号与槽 QObject::connect(senderObject, &QObject::destroyed, receiverObject, [&]() { qDebug() << "senderObject 被销毁,receiverObject 接收到信号"; }); // 断开连接 QObject::disconnect(senderObject, &QObject::destroyed, receiverObject, [&]() { qDebug() << "senderObject 被销毁,receiverObject 接收到信号"; });

在这个例子中,QObject::connect建立了senderObject的destroyed信号与receiverObject的一个匿名槽函数的连接。之后,QObject::disconnect使用相同的参数断开了这个连接。这样,当senderObject被销毁时,匿名槽函数将不再被调用。

2. 断开一个对象的所有信号与另一个对象的所有槽的连接
cpp

QObject *sender = new QObject(); QObject *receiver = new QObject(); // 建立多个连接(这里假设已经建立了多个信号槽连接) // 断开 sender 的所有信号与 receiver 的所有槽的连接 QObject::disconnect(sender, nullptr, receiver, nullptr);

在这个重载形式中,sender的所有信号与receiver的所有槽之间的连接都会被断开。
3. 断开一个对象的特定信号与所有连接的槽的连接
cpp

QObject *object = new QObject(); // 连接信号与多个槽(假设已经建立了多个连接) // 断开 object 的 destroyed 信号与所有连接的槽的连接 QObject::disconnect(object, &QObject::destroyed, nullptr, nullptr);

这里使用nullptr作为接收者和槽函数的参数,表示断开object的destroyed信号与所有连接的槽的连接。

4. 断开一个对象的所有连接

QObject *object = new QObject(); // 连接信号与多个槽(假设已经建立了多个连接) // 断开 object 的 destroyed 信号与所有连接的槽的连接 QObject::disconnect(object, nullptr, nullptr, nullptr);

1.4,QSignalMapper 用法

QSignalMapper 是一种map容器,它的主要作用是能够建立一个对象的映射关系,这个对象是用来发送信号的对象,

void setMapping(QObject *sender, int id);此函数用来建立映射关系。

QSignalMapper 是 Qt 框架中的一个类,它允许将一个信号映射到另一个信号,并可以在映射过程中传递不同的数据。它常用于将多个具有相同信号的对象连接到同一个槽函数,但希望根据发送信号的对象或其他参数执行不同的操作。

QSignalMapper *signalMapper = new QSignalMapper(this); signalMapper->setMapping(ui->btn1,1); signalMapper->setMapping(ui->btn2,2); signalMapper->setMapping(ui->btn3,3); connect(ui->btn1,&QPushButton::clicked,signalMapper,static_cast<void (QSignalMapper::*)()>(&QSignalMapper::map)); connect(ui->btn2,&QPushButton::clicked,signalMapper,static_cast<void (QSignalMapper::*)()>(&QSignalMapper::map)); connect(ui->btn3,&QPushButton::clicked,signalMapper,static_cast<void (QSignalMapper::*)()>(&QSignalMapper::map)); connect(signalMapper,&QSignalMapper::mappedInt,this,&Widget::dealPushbuttons);
void Widget::dealPushbuttons(const int& btnid) { if(btnid == 1) { qDebug()<<"btn1"; } else if(btnid == 2) { qDebug()<<"btn2"; } else if(btnid == 3) { qDebug()<<"btn3"; } }

如上图所示代码,btn按钮的clicked信号与 QSignalMapper 的map()槽函数连接。
map()槽函数会发送 mapped信号。

将mapped信号与我们自定义的槽函数相互连接,然后最终我们自定义的槽函数就能获取map中的key对应的value值,来判断是哪个对象发出的信号,然后做出相应操作。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/6 6:43:03

自动化工具如何重塑API测试与网页交互的工作方式

自动化工具如何重塑API测试与网页交互的工作方式 【免费下载链接】skyvern 项目地址: https://gitcode.com/GitHub_Trending/sk/skyvern 在现代软件开发中&#xff0c;API测试与网页交互自动化已成为提升效率的关键环节。传统工具在处理复杂业务场景时存在明显局限&…

作者头像 李华
网站建设 2026/6/9 8:05:14

OBS多平台推流终极指南:一键实现同步直播全覆盖

OBS多平台推流终极指南&#xff1a;一键实现同步直播全覆盖 【免费下载链接】obs-multi-rtmp OBS複数サイト同時配信プラグイン 项目地址: https://gitcode.com/gh_mirrors/ob/obs-multi-rtmp 在当今直播内容多平台分发的时代&#xff0c;内容创作者面临的最大痛点就是如…

作者头像 李华
网站建设 2026/6/8 17:45:25

2025终极提示工程实战指南:核心技术解密与效率突破

2025终极提示工程实战指南&#xff1a;核心技术解密与效率突破 【免费下载链接】Prompt-Engineering-Guide dair-ai/Prompt-Engineering-Guide: 是一个用于指导对话人工智能开发的文档。适合用于学习对话人工智能开发和自然语言处理。特点是提供了详细的指南和参考资料&#xf…

作者头像 李华
网站建设 2026/6/7 23:15:18

3步搞定中文语义向量:text2vec-base-chinese快速上手指南

3步搞定中文语义向量&#xff1a;text2vec-base-chinese快速上手指南 【免费下载链接】text2vec-base-chinese 项目地址: https://ai.gitcode.com/hf_mirrors/shibing624/text2vec-base-chinese 想要让计算机真正理解中文句子的含义吗&#xff1f;text2vec-base-chines…

作者头像 李华
网站建设 2026/6/7 11:45:05

Paddle-Lite终极指南:在Android设备上快速部署AI模型

Paddle-Lite终极指南&#xff1a;在Android设备上快速部署AI模型 【免费下载链接】Paddle-Lite PaddlePaddle High Performance Deep Learning Inference Engine for Mobile and Edge (飞桨高性能深度学习端侧推理引擎&#xff09; 项目地址: https://gitcode.com/GitHub_Tre…

作者头像 李华
网站建设 2026/6/6 11:38:46

跨环境渲染引擎 - Web UI安全隔离新方案

跨环境渲染引擎 - Web UI安全隔离新方案 【免费下载链接】remote-ui 项目地址: https://gitcode.com/gh_mirrors/re/remote-ui 技术架构概述 跨环境渲染引擎是一种前沿的Web UI渲染解决方案&#xff0c;它通过建立独立的JavaScript执行环境与主页面之间的通信桥梁&…

作者头像 李华