也许你从来都没有听说过柔性数组(flexible array)这个概念,其实以前我也没有听说过,今天在看书时刚刚看到的。
C99,结构体中允许最后一个成员是未知大小的数组,这就叫柔性数组成员。但是结构体的柔性数组成员前面至少有一个其他成员。柔性数组成员允许包含一个可变大小的数组。sizeof返回的结构体大小中不包含这个柔性数组的大小。包含柔性数组的结构体用malloc()函数分配内存的时候,分配的内存大小必须大于结构的大小,这个应该都能理解吧。
实例:
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
typedef struct MyStruct
{
int i;
int a[];
}str,*pStr;
int main()
{
int k=0;
k=sizeof(str);
pStr p=(pStr)malloc(sizeof(str)+100*sizeof(int));
return 0;
}
k的值为4。
这样我们就可以定义一个可变长的结构了。
但是,这时如果用sizeof(*p)测试结构体的大小,你会发现它仍然是4,因为柔性数组只是编外人员,不属于结构体~
这时我们可以用 p->item[n]来访问了。
不过,这其实用的太少了。