news 2026/5/26 7:17:01

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/5/25 10:15:23

JSLint:提升JavaScript代码质量的智能工具

JSLint&#xff1a;提升JavaScript代码质量的智能工具 【免费下载链接】jslint JSLint, The JavaScript Code Quality and Coverage Tool 项目地址: https://gitcode.com/gh_mirrors/js/jslint 还在为JavaScript代码中的潜在问题而烦恼吗&#xff1f;JSLint正是你需要的…

作者头像 李华
网站建设 2026/5/25 20:24:38

Syncthing Tray:5个让你爱上无服务器文件同步的理由

Syncthing Tray&#xff1a;5个让你爱上无服务器文件同步的理由 【免费下载链接】syncthingtray Tray application and Dolphin/Plasma integration for Syncthing 项目地址: https://gitcode.com/gh_mirrors/sy/syncthingtray 想要摆脱云存储的束缚&#xff0c;又担心复…

作者头像 李华
网站建设 2026/5/25 9:03:48

ConvertX用户体验优化:从卡顿到流畅的完整实践指南

ConvertX用户体验优化&#xff1a;从卡顿到流畅的完整实践指南 【免费下载链接】ConvertX &#x1f4be; Self-hosted online file converter. Supports 700 formats 项目地址: https://gitcode.com/GitHub_Trending/co/ConvertX 当用户上传一个500MB的设计文件&#xf…

作者头像 李华
网站建设 2026/5/25 7:17:18

CVAT权限管理实战:从混乱到有序的团队协作指南

你是否曾遇到过团队成员误删重要标注数据&#xff1f;或者因为权限分配不当导致项目进度受阻&#xff1f;在计算机视觉标注工作中&#xff0c;CVAT作为行业领先的工具&#xff0c;提供了完善的用户权限管理系统。本文将带你从实际问题出发&#xff0c;通过四段式结构&#xff0…

作者头像 李华
网站建设 2026/5/25 6:04:41

XCOM V2.6:嵌入式开发的智能通信管家

XCOM V2.6&#xff1a;嵌入式开发的智能通信管家 【免费下载链接】XCOMV2.6正点原子串口调试工具最新版 XCOM V2.6是一款由正点原子开发的串口调试工具&#xff0c;专为嵌入式开发人员和电子爱好者设计。该版本在原有功能的基础上进行了多项修复和优化&#xff0c;提升了用户体…

作者头像 李华
网站建设 2026/5/26 4:53:26

3个简单步骤:快速实现跨平台自动化工具配置

3个简单步骤&#xff1a;快速实现跨平台自动化工具配置 【免费下载链接】skyvern 项目地址: https://gitcode.com/GitHub_Trending/sk/skyvern 企业级自动化工具常面临浏览器兼容性难题&#xff0c;不同内核的渲染差异、API支持度差异&#xff0c;可能导致自动化流程在…

作者头像 李华