1.柔性数组是什么
1.1 定义
struct st
{
int i;
int a[0];
};
struct st a;
a. 以上面的结构体实例为说明依据, 这个int a [] 就是柔性数组。
struct st
{
int i;//4字节
int a[0];//柔性数组成员,也可以写int a[];
//因为是柔性数组,无法确认a占几个字节
};
int main()
{
printf("%d\n", sizeof(struct st));//打印4
return 0;
}
b. 在代码编译阶段, 使用运算符sizeof(struct st)计算 结构体的类型的大小是 4字节
1.2 注意事项:
a. 设计这样的结构体必须要创建别的成员,例如结构体成员 int i;
b. 编译器不同,对柔性数组的设计不同,可以设计成int a[],或者设计成 int a[];
2. 柔性的使用
2.1 通过从堆上分配空间
struct st
{
int i;//4字节
int a[0];//柔性数组成员,也可以写int a[];
//因为是柔性数组,无法确认a占几个字节
};
int main()
{
struct st *a;
//此处分配出成员i 和 柔性数组的空间
a = (struct st *)malloc(sizeof(struct st) + 10 *sizeof(int));
return 0;
}
2.2 下面的是通过遍历的方式为柔性数组赋值
int j;
for(j = 0; j < 10; j++)
{
a->a[j] = j;
}
2.3 柔性数组a[] + i 空间释放进行释放
free(a);
个人不建议只对柔性数组部分进行释放
2.4 柔性的优点
struct st
{
int i;//4字节
int *a;//4字节,这里计算结构体大小恰好是8字节
};
上面是普通的结构体的定义方式, 可用指针a 指向一块内存,用作数组存储数据
第一个好处是:方便内存释放,都是统一的做释放。采用指针变量,通过先去释放成员指针的指向的内存,再去释放结构体指针对应的空间
第二个好处是:加快访问速度
添加柔性数组的结构体指针指向的内存,都是连续的内存有益于提高访问速度,也有益于减少内存碎片。