使用qt编写上位机程序,出现串口死掉无法接受数据的bug

项目场景:

使用qt编写上位机程序,出现串口死掉无法接受数据的bug


问题描述

串口打开后一段时间内可以接受串口数据,过了一段时间后,端口就失去了响应,观察下位机指示灯发现下位机的串口还是在正常发送数据,使用其它串口工具打开也能正常接收数据,当上位机的串口死掉之后关掉串口重新打开又能正常接收数据了,过一会儿又会死掉,关掉串口再重新打开又恢复正常。

经调试发现,串口死掉之后时的串口状态仍是open状态,查看缓冲区并没有满,调用error()方法打印错误信息为noerror


原因分析:

多种可能:

1、程序采用的信号机制来读取信息,当产生readyread信号之后,由槽函数进行数据读取并处理,数据的读取和处理位于了同一个线程,可能导致下一包数据来时,上一包的数据还在处理,无法响应readyread信号并读物数据,进而导致上位机的串口缓冲区溢出,再无法触发readyread信号;

2、程序使用了很多定时器,有可能定时器触发定时信号和readyread信号冲突了,信号没有得到处理,进而影响了后续的readyread信号产生;

等等


解决方案:

1、串口和数据处理以及UI显示分别在不同的线程中处理;

2、设置各定时器的定时周期时避免同线程内出现多定时器同时触发的情况,譬如timerA定时周期为2ms、tiemrB的定时周一为1ms,那么在两个定时器同时启动之后,在初始值分别为2ms和1ms的情况下,2ms后两个定时器会同时触发。

3、将信号与槽的连接尽量选择队列的方式,避免,信号没有被处理完,或者产生冲突;

4、设置串口超时处理函数,在串口超时处理函数里以下两行代码:

cpp 复制代码
port->clear(QSerialPort::Input);  // 仅清空输入缓冲区
QCoreApplication::processEvents(); // 强制处理事件队列‌

我是在试了1、2、3之后问题还是没有解决,甚至尝试了在超时函数里面尝试了重启串口,没想到问题没解决还出现了程序闪退的问题。最终在删掉重启串口的操作,添加4之后问题得到解决,这个bug折磨了我近半个月,好在解决了。

相关推荐
晚风吹长发5 小时前
二分查找算法+题目详解
c++·算法·二分查找
罗义凯6 小时前
其中包含了三种排序算法的注释版本(冒泡排序、选择排序、插入排序),但当前只实现了数组的输入和输出功能。
数据结构·c++·算法
怎么就重名了6 小时前
STM32+蓝牙模块+超声波模块+QT
stm32·嵌入式硬件·qt
春蕾夏荷_7282977257 小时前
c++ easylogging 使用示例
c++·log·easylogging
syt_biancheng7 小时前
Day3算法训练(简写单词,dd爱框框,3-除2!)
开发语言·c++·算法·贪心算法
864记忆7 小时前
Qt Network 模块中的函数详解
开发语言·网络·qt
864记忆7 小时前
Qt Sql 模块中的函数详解
开发语言·网络·qt
自然数e7 小时前
C++多线程【线程管控】之线程转移以及线程数量和ID
开发语言·c++·算法·多线程
Elias不吃糖10 小时前
epoll 事件全集、每个事件的含义、哪些事件在实际服务器中最常见、哪些会组合出现
linux·c++·event
AA陈超10 小时前
ASC学习笔记0017:返回此能力系统组件的所有属性列表
c++·笔记·学习·ue5·虚幻引擎