遇到了一个关于零数组定义的问题,总结如下:
零数组的使用的好处是:它在结构里不占用空间,但是结构可以通过它访问结构之外的数据。这也给了它的很大的访问权限,
因此在通过零数组访问之前,一定要检查访问范围的有效性。下面是一个简单的例子:
#include <stdio.h>
#include <stdlib.h>
typedef struct {
int len;
char data[0];
} array_t;
int data_len = 10;
int main()
{
array_t *tmp;
tmp = malloc(sizeof(array_t)+data_len);
int i;
for (i = 0; i < data_len; i++)
tmp->data[i] = i;
tmp->len = data_len;
printf("data[9] = %d/n", tmp->data[9]);
printf("sizeof(array_t) is %d/n", sizeof(array_t));
printf("data[-4] = %d/n", tmp->data[-4]);
}
输出结果是:
data[9] = 9
sizeof(array_t) is 4
data[-4] = 10
在网上搜到了这篇文章,值得收藏。
GCC hacks in the Linux kernel
中文链接:http://www.ibm.com/developerworks/cn/linux/l-gcc-hacks/index.html
英文链接:http://www.ibm.com/developerworks/linux/library/l-gcc-hacks/index.html?S_TACT=105AGX52&S_CMP=content