什么是柔性数组?
C99 中,结构中的最后一个元素允许是未知大小的数组,这就叫做『柔性数组』成员。
我对此的理解 为
1.是结构体的最后一个元素。
2.具有0个元素。
3.无大小
例:
#include<stdio.h>
struct student {
char clss[32];
char name[32];
int score[];
};
int main()
{
printf("%d", sizeof(struct student));
return 0;
}
我们知道在C语言的语法中不允许存在大小未知的数组,但由上柔性数组是个例外,在结构体中 arr[]是不会发生报错。
柔性数组的特点:
结构中的柔性数组成员前面必须至少一个其他成员。
sizeof 返回的这种结构大小不包括柔性数组的内存。
包含柔性数组成员的结构用malloc ()函数进行内存的动态分配,并且分配的内存应该大于结构的大小,以适应
柔性数组的预期大小。
柔性数组的简单使用测试
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
struct student {
char clss[32];
char name[32];
int score[];
};
int main()
{
struct student *p = (struct student *)malloc(sizeof(struct student) + sizeof(int) * 10);
assert(p);
for (int i = 0; i < 10; i++) {
p->score[i] = i;
printf("%d\n",p->score[i]);
}
free(p);
return 0;
}
这样柔性数组成员score,相当于获得了10个整型元素的连续空间。
拓展:
C语言结构体里的数组与指针