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个字节 ……
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。