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个字节 ……