daemon将上面分配的cmd包发送给library,library接收到包后,需要将data字段中的数据取出来。size指明了整个包的长度,但没有字段指明数据的长度。我需要这么一个指明数据长度的字段吗?
于是乎,这段程序成功的给我带来了无数的bug,莫名奇妙的segfault,奇怪的数据错误,还是有部分时间的正常工作。当然,最终我还是找到了问题:
sizeof (packet) == 12;
这是合理的,char reply被padding成了4个字节,而char data[0]字节为0。
但,offsetof(packet, data) == 9,在计算偏移时,char reply为一个字节,没有padding。
所以packet_data_len每次都会返回比真实的数据多3个字节 ……
本文深入探讨了一个在包结构与内存复制过程中遇到的问题,详细解释了sizeof与offsetof函数的区别,以及如何正确计算数据长度,避免了段错误和数据错误的发生。通过实例分析,揭示了内存管理中的常见误区,并提供了修正方案。
5万+

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



