typedef struct{
int a;
char data[]; // 以前也写成 char data[0], 这个写法更规范
} my_data;
sizeof(my_data) = 4;
flexible array member
C语言的经典写法
#define offsetof(type, element) ((int)&((type *)0)->element)
static inline size_t packet_data_len(packet* cmd) {
assert(cmd);
return cmd->size - offsetof(packet, data);
}
memcpy (buffer_to_receive_data, cmd->data, packet_data_len (cmd)); //越界鸟
但是很危险呀。
sizeof (packet) == 12;
这是合理的,char reply被padding成了4个字节,而char data[0]字节为0。
但,offsetof(packet, data) == 9,在计算偏移时,char reply为一个字节,没有padding。
所以packet_data_len每次都会返回比真实的数据多3个字节 ……
本文详细探讨了C语言中结构体的应用,特别是带有变长数组成员的结构体大小及偏移量计算。通过具体示例解释了offsetof宏的使用方法,并分析了packet结构体在内存对齐情况下的数据长度计算问题。
745

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



