qt信号槽跨线程使用时候的坑

https://www.cnblogs.com/zhuchunlin/p/18541548

信号槽connect的时候扩展有5种,在跨线程使用的时候选择不同的参数会有不同的效果,使用不当会造成线程同步甚至崩溃的问题。5种参数的意义不再累述,可以参考 信号槽的多线程安全性讨论

第一个坑 跨线程时connect使用Direct Connection (直接连接)

跨线程触发槽的时候,因为信号和槽不在一个线程内需要考虑同步问题(参考 信号槽的多线程安全性讨论),比较简单的方式是槽函数加全局锁。除此之外还有一个更简单的方式,就是connect的使用Direct Connection (直接连接),这种连接方式将会使槽函数在信号发出的线程中直接执行,这种情况业务处理实际就变成了单线程,并发问题自然没有了。

但是这种情况有一个致命问题,比如A,B分属两个线程,A使用直连方式调用B的槽函数,其实是在A线程内创建了一个B的临时对象,然后调用B的槽函数。B的临时对象是使用默认构造函数创建的,如果B没有默认构造函数,这种情况运行程序将会直接崩溃。

qt官方文档上也有说明这一使用方式的不安全性 ,只是没有说明具体的原因。建议跨线程时不要使用Direct Connection去解决同步问题。

第二个坑 跨线程时connect使用 Queued Connection(队列连接)信号触发太频繁而槽函数处理时间又太长

队列连接的时候,信号传递的参数存放在槽函数所在线程的消息队列里,这个消息队列基于事件机制向对应线程分发任务,这个过程是线程阻塞的。如果信号频繁触发,而槽函数处理的时间又太长,长过信号触发的间隔时间,就会造成消息队列不停增长,内存不断增加直到崩溃。

这种情况没什么太好的解决方式,只能是在程序设计的时候尽量避免。

信号槽在提供便利性的同时不仅牺牲了效率,而且造成了使用的复杂性,qt中类似的坑有很多。个人感觉qt的优势还是在于界面,非界面开发的时候综合开发体验还是比c++11和boost差的太多了,这又是另一个话题了。


原文链接:https://blog.csdn.net/u010810750/article/details/104741912

相关推荐
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题 第87题】【Mysql篇】第17题:分布式事务的实现原理?
java·数据库·分布式·mysql·面试
来杯@Java3 小时前
图书管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·mybatis·课程设计
卷毛的技术笔记4 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
编程大师哥4 小时前
匿名函数 lambda + 高阶函数
java·python·算法
isyangli_blog4 小时前
OpenDayLight (Carbon 版本) 启动与组件安装
开发语言·php
vb2008114 小时前
FastAPI APIRouter
开发语言·python
Benszen4 小时前
KVM虚拟化解决方案
开发语言·perl
会编程的土豆4 小时前
Go 语言反射(Reflection)详解
开发语言·后端·golang
東雪木4 小时前
多线程与并发编程 专属复习笔记
java·开发语言·笔记·java面试
adrninistrat0r4 小时前
Java调用链MCP分析工具
java·python·ai编程