当前位置: 首页 > news >正文

【Qt之信号和槽】对象多层嵌套后,高效使用信号和槽

抛出问题

Qt的信号槽机制非常牛逼,也是Qt的独特的核心功能之一。
有时候在很多窗体中传递信号来实现更新或者处理,如果窗体层级比较多,比如窗体A的父类是窗体B,窗体B的父类是窗体C,窗体C有个子窗体D,如果窗体A一个信号要传递给窗体D,问题来了,必须先经过窗体B中转到窗体C再到窗体D才行,这样的话各种信号关联信号的connect会非常多而且管理起来比较乱

解决方案

可以考虑增加一个全局的单例类AppEvent,公共的信号放这里,然后窗体A对应信号绑定到AppEvent,窗体D绑定AppEvent的信号到对应的槽函数即可,干净清爽整洁。

示例

下面是一个简单的C++示例代码,使用全局单例类来实现在窗体层级比较多的情况下传递信号:

#include <QObject>// 定义一个全局单例类
class AppEvent : public QObject
{Q_OBJECT
public:static AppEvent* instance(){static AppEvent instance; // 构造函数为私有,只能通过静态成员函数创建实例return &instance;}signals:// 定义公共信号void signalToBeTransmitted(int value);
};// 窗体D
class WindowD : public QObject
{Q_OBJECT
public slots:// 槽函数,处理信号void handleSignalFromAppEvent(int value){// 处理信号}
};// 窗体A
class WindowA : public QObject
{Q_OBJECT
public:WindowA(){// 将窗体A的信号连接到全局的AppEvent的信号上connect(this, &WindowA::signalFromWindowA, AppEvent::instance(), &AppEvent::signalToBeTransmitted);}signals:// 定义窗体A的信号void signalFromWindowA(int value);
};// 窗体B
class WindowB : public QObject
{Q_OBJECT
public:WindowB(){// 将AppEvent的信号连接到窗体B的槽函数上connect(AppEvent::instance(), &AppEvent::signalToBeTransmitted, this, &WindowB::handleSignalFromAppEvent);}public slots:// 窗体B的槽函数,处理信号void handleSignalFromAppEvent(int value){// 处理信号}
};// 窗体C
class WindowC : public QObject
{Q_OBJECT
public:WindowC(){// 将AppEvent的信号连接到窗体C的槽函数上connect(AppEvent::instance(), &AppEvent::signalToBeTransmitted, this, &WindowC::handleSignalFromAppEvent);}public slots:// 窗体C的槽函数,处理信号void handleSignalFromAppEvent(int value){// 处理信号}
};int main()
{// 创建窗体层级关系WindowD windowD;WindowC windowC;WindowB windowB;WindowA windowA;// 发射窗体A的信号emit windowA.signalFromWindowA(42);return 0;
}

思路

  • 定义了一个全局的单例类AppEvent,其中定义了一个公共信号signalToBeTransmitted
  • 窗体A的信号signalFromWindowA连接到了AppEvent的信号signalToBeTransmitted上,
  • 窗体D的槽函数handleSignalFromAppEvent则连接到了AppEvent的信号上,以处理信号。

结论

使用全局单例类AppEvent可以简化信号的传递过程,使代码更加整洁和可维护。

http://www.lryc.cn/news/188820.html

相关文章:

  • 搬砖日记:vue2 用require引入图片项目编译失败
  • 国内外都可以使用的【免费AI工具】,实用性满满
  • 银河麒麟服务器x86安装ntp客户端,并配置成功可以同步时间
  • vue踩的坑:属性报undefined错误问题汇总
  • Ubuntu22.04.3安装教程
  • Vue2和Vue3的emit、props、watch等知识点对比
  • HTML 笔记:初识 HTML(HTML文本标签、文本列表、嵌入图片、背景色、网页链接)
  • 使用弹性盒子flex对html进行布局和动态计算视口高度
  • 华为云云耀云服务器L实例评测|华为云耀云服务器L实例评测用例(五)
  • uniapp-vue3微信小程序实现全局分享
  • Qt如何实现动态背景-视频背景
  • vue按键全屏和F11全屏共存
  • springboot就业信息管理系统springboot32
  • 深入探讨芯片制程设备:从原理到实践
  • Vuex的简介以及入门案例
  • 上海亚商投顾:沪指探底回升 华为汽车概念股集体大涨
  • Android网络监听
  • Kubernetes 常用命令 持续更新
  • 达梦数据库常用命令行
  • 【通信系列 6 -- AT 命令介绍】
  • flask捕获@app.errorhandler/@app.after_request全局异常总结
  • 智能晾衣架丨以科技解放双手
  • asp.net饭店订餐管理系统VS开发sqlserver数据库web结构c#编程Microsoft Visual Studio计算机设计定制
  • Pushgateway的场景使用
  • 时间范围配置(昨天,今天,本周,本月,本季度,本年)
  • PlantUML 绘图
  • spring boot自定义配置时在yml文件输入有提示
  • Linux:I/O 5种模型
  • 企业提升效率的秘密武器,推荐J2L3x聊天软件!
  • Android Termux安装MySQL,并使用cpolar实现公网安全远程连接[内网穿透]