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

QT connect使用简单介绍

在这里插入图片描述
如图,首先 connect是线程安全的。其次它有很多重载,当然最重要的还是QT4连接和QT5连接的区别,这个函数重载表示connect函数也是支持lambda函数的。

connect(const QObject *sender, PointerToMemberFunction signal, Functor functor)

connect 函数的第五个参数

在这里插入图片描述
了解 connect的第五个参数是非常重要的。其中Qt::UniqueConnection是比较特殊的,它仅仅用于connect的在两个对象之间一个信号和一个槽之间连接的唯一性。注意 在QT中一个对象的信号重复连接到另外一个对象的槽上,那么当信号发送时,每个连接的槽都会执行。如果只希望连接一次那么就可以使用Qt::UniqueConnection。当出现重复的连接时就会连接失败。问题 如何判断连接是否失败了?答案就是connect的返回值。
在这里插入图片描述
因为QMetaObject::Connection重载了运算符bool所以可以将该类直接用于条件判断。代码如下

#include "widget.h"
#include "ui_widget.h"
#include <QDebug>Widget::Widget(QWidget *parent) :QWidget(parent),ui(new Ui::Widget)
{ui->setupUi(this);QMetaObject::Connection con = connect(ui->pushButton, &QPushButton::clicked, this, &Widget::slotClicked, Qt::UniqueConnection);QMetaObject::Connection con_1 = connect(ui->pushButton, &QPushButton::clicked, this, &Widget::slotClicked, Qt::UniqueConnection);if(con_1){qDebug() << QStringLiteral("第二次连接成功");}else{qDebug() << QStringLiteral("第二次连接失败");}
}Widget::~Widget()
{delete ui;
}void Widget::slotClicked()
{qDebug() << QStringLiteral("按钮被点击了");
}

这里又可以体现出lambda表达式的坏处。lambda最大的好处就是使用非常方便。不好的地方有使用lambda函数导致调试困难。

    QMetaObject::Connection con = connect(ui->pushButton, &QPushButton::clicked, this, [](){qDebug() << QStringLiteral("按钮被点击了");}, Qt::UniqueConnection);if(con){qDebug() << QStringLiteral("con连接成功");}else{qDebug() << QStringLiteral("con连接失败");}QMetaObject::Connection con_1 = connect(ui->pushButton, &QPushButton::clicked, this, [](){qDebug() << QStringLiteral("按钮被点击了");}, Qt::UniqueConnection);if(con_1){qDebug() << QStringLiteral("con_1连接成功");}else{qDebug() << QStringLiteral("con_1连接失败");}

此时就算两个匿名函数的函数体一样,但是由于名字不一样所以两个都可以连接成功。使用匿名函数导致调试困难
在这里插入图片描述
即使是debug模式仍然不会进入断点。

剩下的四个参数

Qt::AutoConnection 默认就是此链接,如果发送对象和接收对象在同一个线程,那么就是Qt::DirectConnection链接如果不是在同一个线程上那么就是Qt::QueuedConnection
Qt::BlockingQueuedConnectionQt::QueuedConnection相同,不同的是发送信号的线程将会阻塞直到被执行的槽函数返回。如果在同一个线程进行该参数的连接会导致死锁。

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

相关文章:

  • 【云原生】kuberneter中Helm入门到实践
  • 编译鸿蒙codelabs安装时报错
  • 设计模式
  • 用gdal库读取tif影像并填充边缘,并根据窗口大小滑动裁剪裁剪(包含gdal转PIL)
  • sqlserver数据库导出到mysql
  • 【抓包工具】whistle抓包工具分享
  • docker可视化工具Portainer
  • 售后服务管理系统哪家好?云部署的售后服务软件有什么优势?
  • laravel-admin之 解决上传图片不显示 $form->image(‘image‘); 及 $grid->column(‘image‘);
  • 运营商三要素 API:构建安全高效的身份验证系统
  • 使用 BERT 进行文本分类 (01/3)
  • layui第三方组件cron的使用
  • Linux 信号的基本概念
  • 神经网络基础-神经网络补充概念-31-参数与超参数
  • C# Linq源码分析之Take (二)
  • FPGA控制RGB灯WS2812B
  • 【Linux】【驱动】应用层和驱动层传输数据
  • 【第二阶段】kotlin函数引用
  • sip网络号角喇叭 sip音柱 POE供电广播音箱 ip网络防水对讲终端 sip网络功放
  • 【网络】传输层——TCP(滑动窗口流量控制拥塞控制延迟应答捎带应答)
  • Electron教程_编程入门自学教程_菜鸟教程-免费教程分享
  • LVS负载均衡DR(直接路由)模式
  • 14 anaconda+pycharm环境管理以及源管理
  • 【C语言程序设计】C语言基本数据类型与表达式(思考题)
  • Linux 网络发包流程
  • Python web实战之Django的AJAX支持详解
  • spring boot实现实体类参数自定义校验
  • 网络安全威胁与防御策略
  • C++:哈希表——模拟散列表
  • 项目配置中心介绍