Qt信号与槽会被阻塞的问题

最新在开发的时候发现这么一个情况
把自定义信号connect到一个槽函数,而在槽函数内部执行的时候用了一个eventloop阻塞当前代码执行,这样的结果就是在emit了自定义的信号后就被槽函数的调用阻塞住了,不会再往下执行,如下:

signals:
	void signal_one();
connect(this, SIGNAL(signal_one()), this, SLOT(funcB()));

void funcA() {
	emit signal_one();
	std::cout << "after emit" << std::endl;
}

void funcB() {
	QEventLoop loop;
	loop.exec();
}

这样的结果就是那句after emit并不会被打印,所以大概可以知道Qt的信号触发的槽函数和发出信号本身是处在同一个线程当中的,无法异步执行

我用的解决办法是在类中定义一个QTimer *timer,然后connect(timer, SIGNAL(timeout()), this, SLOT(funcC()));在funcB中就只是执行timer.start(10);,而在funcC中去执行阻塞的操作,这样在funcA中emit信号之后,那句after emit就可以被打印出来。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,我们可以得知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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值