typedef struct packge_data_header
{
| uint16_t totalCount;
| uint16_t seq;
| uint32_t totalSize;
| }PACKAGE_DATA_HEADER;
typedef struct nav_header {
| uint16_t ICode; ////固定识别码
| uint16_t Command; ////命令字
| uint16_t session_id; ////端口id
| uint16_t DataLength; ////数据段长度 -----这个字段溢出,导致发送长度变小
| }NAVICAT_HEADER;
定位:
1、把每次发送的长度和包数打印出来
2、把对应接收端接收的长度和包数打印出来
发现都一样
3、但组包后的长度不对,由此推断组包环节有问题
4、将组包后的包头中数据长度打印出来,发现长度较小,明显有问题
5、仔细走查代码发现,这个长度字段最大范围是65535,数据大的时候会发生溢出
本文探讨了在软件开发过程中遇到的包头数据长度溢出问题,如何通过打印发送和接收长度来定位问题,并最终发现是由于结构体中数据长度字段的最大值限制所引起的。通过实例和代码分析,揭示了修复方案和预防措施。
3596

被折叠的 条评论
为什么被折叠?



