qt信号槽连接方式Qt::UniqueConnection的使用

11 篇文章 0 订阅

qt信号槽连接方式Qt::UniqueConnection的使用

前言

qt信号槽连接方式一共有以下五种。简介如下图所示。
在这里插入图片描述

本文记录第五种Qt::UniqueConnection的使用方法 。

Qt::AutoConnection
Qt::DirectConnection
Qt::QueuedConnection
Qt::BlockingQueuedConnection
Qt::UniqueConnection

准确来说是四种,第五种Qt::UniqueConnection,是配合前四种使用的。确保相同的信号,相同的槽保持唯一连接。
qt官方文档给出了使用方式
在这里插入图片描述
使用OR来配合前四种方式使用。但是笔者没有弄懂如何使用,直接用 | 符号是无法通过编译的。

Qt::AutoConnection |  Qt::UniqueConnection

去百度搜了很久,有个论坛给了我启发。
qtcn论坛地址
在这里插入图片描述
他这里使用两个类型取或创建了一个新的连接方式。受他的启发,我自己尝试了一下发现一下方式可以使用。

使用方式

connect(m_timer,&QTimer::timeout,this,&tOne::printSth,
            Qt::ConnectionType(Qt::AutoConnection | Qt::UniqueConnection));

用 Qt::ConnectionType包起来可以实现。
Qt::UniqueConnection的作用就是使相同信号唯一连接相同槽。但是你在下一次连接的时候,如果不使用Qt::UniqueConnection,下次连接还是会成功,不会使唯一连接生效。要两次都使用Qt::UniqueConnection,才会生效。

测试代码

举例:以下例子中,两次连接都会成功,打印连接结果都是true

    auto rc = connect(m_timer,&QTimer::timeout,this,&tOne::printSth,
            Qt::ConnectionType(Qt::AutoConnection | Qt::UniqueConnection));
    qDebug() << rc;
    rc = connect(m_timer,&QTimer::timeout,this,&tOne::printSth,
                           Qt::ConnectionType(Qt::AutoConnection));
    qDebug() << rc;

举例:以下例子中,第一次连接会成功,返回true 。第二次会失败(唯一连接),返回false。

    auto rc = connect(m_timer,&QTimer::timeout,this,&tOne::printSth,
            Qt::ConnectionType(Qt::AutoConnection | Qt::UniqueConnection));
    qDebug() << rc;
    rc = connect(m_timer,&QTimer::timeout,this,&tOne::printSth,
              Qt::ConnectionType(Qt::AutoConnection | Qt::UniqueConnection));
    qDebug() << rc;

其他使用方式

如果直接使用Qt::UniqueConnection,不加其他参数,等同于上述的Qt::ConnectionType(Qt::AutoConnection | Qt::UniqueConnection)),因为信号槽连接,默认为Qt::AutoConnection
这种方式也可以保证唯一连接
不过,依然要每次都使用Qt::UniqueConnection,才会保证唯一连接生效。

connect(m_timer,&QTimer::timeout,this,&tOne::printSth,Qt::UniqueConnection);
  • 16
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
根据提供的引用内容,我们可以得知QT信号的第五个参数是连接类型。连接类型有五种,分别是: 1. Qt::AutoConnection:自动连接方式,如果信号在同一线程中,则采用直接连接方式,否则采用队列连接方式。 2. Qt::DirectConnection:直接连接方式,当信号发射时,函数会立即执行,无论信号在哪个线程中。 3. Qt::QueuedConnection:队列连接方式,当信号发射时,函数会被放入接收者对象所在的线程的事件队列中,等待事件循环处理。 4. Qt::BlockingQueuedConnection:阻塞队列连接方式,当信号发射时,函数会被放入接收者对象所在的线程的事件队列中,但是发射信号的线程会被阻塞,直到函数执行完毕。 5. Qt::UniqueConnection:唯一连接方式,如果信号已经连接到了某个函数,再次连接时会失败。 下面是一个例子,演示了如何使用第五个参数来连接信号: ```cpp // 定义一个信号 class Sender : public QObject { Q_OBJECT signals: void mySignal(int value); }; // 定义一个函数 class Receiver : public QObject { Q_OBJECT public slots: void mySlot(int value) { qDebug() << "Received value: " << value; } }; // 在main函数中连接信号 int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); Sender sender; Receiver receiver; // 使用Qt::QueuedConnection连接信号 QObject::connect(&sender, SIGNAL(mySignal(int)), &receiver, SLOT(mySlot(int)), Qt::QueuedConnection); // 发射信号 emit sender.mySignal(100); return a.exec(); } ```
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值