Qt 信号和槽 connect()第5个参数

一、Qt connect第5个参数:
1、Qt::AutoConnection
*默认值。使用该值则具体连接类型会在信号发送时决定。
*如果接收者和发送者在同一个线程,则自动使用Qt::DirectConnection类型。
*如果接收者和发送者不在同一个线程,则自动使用Qt::QueuedConnection类型。

2、Qt::DirectConnection
*槽函数会在信号发送时直接被调用。
*无论槽函数所属对象在哪个线程,槽函数都在发送信号的线程内执行。
*emit语句后面的代码将在与信号关联的所有槽函数执行完毕后才被执行。
*效果类似函数调用。

3、Qt::QueuedConnection
*信号发出后,信号被暂时放到消息队列中,等接收对象所属线程的事件循环取得控制权并取得该信号时,然后执行和信号关联的槽函数。
*emit语句后的代码在发出信号后,立马被执行,无需等待槽函数执行完毕。
*接收者和发送者可以在同一线程,也可以跨线程,但槽函数在接收者所依附的线程内执行。

4、Qt::BlockingQueuedConnection
*槽函数调用时机和Qt::QueuedConnection一致。
*但emit信号后,发送者线程会立马阻塞,直到槽函数运行完,才会执行emit后面的代码。
*注意,发送者和接收者绝对不能在同一线程,否则程序会死锁。
*在多线程需要同步的场合,可能需要该参数。

5、Qt::UniqueConnection
*该flag可以和以上四个按位或(|)结合使用。
*当设置该flag时,若某个信号和槽已经连接,再进行重复连接就会失败,目的是避免重复连接。

6、注意:
*一般connect的第5个参数会在多线程中使用。
*QThread对象所管理的线程,是run启动的线程,是新建线程。
*QThread对象所依附的线程,是创建QThread对象的线程。
*除非通过MoveToThread将QThread对象依附到次线程中。

二、信号和槽注意点:
1、 使用信号槽,类必须继承于QObject类,并且私有声明包含Q_OBJECT。
2、 信号和槽函数,参数类型一致,允许信号参数比槽参数多,但前面共有几个必须类型一致。
3、 Qt5之后,槽函数可以无需slots关键字。
4、 一个信号可以和多个槽连接; 多个信号可以和一个槽连接; 一个信号可以连接另一个信号;槽可以用disconnect取消连接。
5、 public slots表示所有对象都可将信号和之连接; protected slots表示当前类和子类对象可将信号与之连接;private slots表示只有本类对象能将信号与之连接。

根据提供的引用内容,我们可以得知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(); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员小马兰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值