QTcpSocket断开重连后调用write后奔溃问题解决方案

当客户端断开后调用connectToHost重连服务器成功后调用write发送数据会导致程序奔溃,找了好久最后发现是信号和槽连接方式有问题。

原来是:

cpp 复制代码
    connect(this->electricBoxSocketClient,&QTcpSocket::disconnected,this,
            [=]()
            {
                emit deviceErrorSignal(0,true,true,"连接断开");
            });

修改为:

c 复制代码
    connect(this->electricBoxSocketClient,&QTcpSocket::disconnected,this,
            [=]()
            {
                emit deviceErrorSignal(0,true,true,"连接断开");
            },Qt::QueuedConnection);

就合适了。

disconnected信号与槽的连接方式改为Qt::QueuedConnection

Qt::QueuedConnection连接方式介绍:

在Qt中,Qt::QueuedConnection是一种信号与槽的连接方式,它指示信号与槽之间的通信通过事件队列进行,即发送信号的对象会将信号发送到事件队列中,然后由事件循环来处理并调用槽函数。

使用Qt::QueuedConnection时,信号发出时不会直接调用连接的槽函数,而是将一个事件放入接收者对象的事件队列中。在事件循环中处理事件时,会依次调用事件队列中的槽函数。

这种连接方式主要用于不同线程间的通信,因为Qt的跨线程通信是通过事件分发机制实现的。Qt::QueuedConnection还可以用于线程内部的通信,以确保信号与槽的调用都在事件循环中进行,避免了多线程并发访问的问题。

需要注意的是,Qt::QueuedConnection并不保证信号和槽函数的执行顺序,因为它们是在不同的事件循环中执行的。如果需要保证执行顺序,可以考虑使用Qt::BlockingQueuedConnection连接方式。

使用Qt::QueuedConnection的语法如下:

cpp 复制代码
connect(sender, &Sender::signal, receiver, &Receiver::slot, Qt::QueuedConnection);

其中,sender是发送信号的对象,signal是发送的信号,receiver是接收信号的对象,slot是接收信号的槽函数。最后一个参数Qt::QueuedConnection表示使用Qt::QueuedConnection连接方式。

相关推荐
ClouGence14 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
荣--14 小时前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森15 小时前
动手实战学 Docker — 从零到集群编排完全指南
运维
飞将16 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Avan_菜菜1 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
Nturmoils2 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波2 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
SelectDB2 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
倔强的石头_3 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3104 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql