目录
何为柔性数组(Flexible Array)
柔性数组在C语言的 C99 标准中,引入的新特性。结构中的最后一个元素的大小允许是未知的数组,即为柔性数组。
struct S {
int i;
int arr[]; //柔性数组成员
/*int arr[0];*/ //这两种写法都可以,具体看编译器
};
1.柔性数组的特点
- 柔性数组不能单独的出现在结构体之中,至少要包含一个及以上其它成员,且要在末尾
- 利用sizeof计算的结构体大小,并不会去计算柔性数组的大小
- 包含柔性数组成员的结构体要利用malloc来进行动态内存分配,且分配的内存大小要大于结构体内存大小,来达到预期的所需内存的大小。
2.柔性数组的创建和简单使用
创建
struct S {
int i;
int arr[];
};
int main() {
struct S *s = (struct S*)malloc(sizeof(struct S)+5*sizeof(int));
//使用malloc创建了一个大小为: (结构体本身大小) + 柔性数组你所期望的大小
struct S *s = (struct S*)malloc(sizeof(struct S)+10*sizeof(int));
//调整柔性数组大小
return 0;
}
这就是为什么柔性数组为什么要在成员末尾的原因,只有它在末尾,开辟内存的大小变化时,柔性数组的大小才会随着变化,这就是所谓的柔性数组
简单使用
代码一
struct S {
int i;
int arr[];
};
int main() {
struct S *p = (struct S*)malloc(sizeof(struct S)+5*sizeof(int));
if(p == NULL)
return 1;
//业务处理
p->i = 100;
for (int i = 0; i < 100; i++)
{
p->arr[i] = i;
}
//释放空间
free(p);
p = NULL;
return 0;
}
3.柔性数组的优势
在上柔性数组的简单使用中,我们的代码换种写法也可以达到跟柔性数组一样的功能
把柔性数组成员换成:指针变量
代码二
struct S {
int i;
int *parr;
};
int main() {
struct S* p = (struct S*)malloc(sizeof(struct S));
if (p == NULL)
return 0;
p->parr = (int*)malloc(5 * sizeof(int));//多一次malloc就必然要多一次检查和内存释放
if (p->parr == NULL)
return 0;
//业务处理
p->i = 100;
for (int i = 0; i < 100; i++)
{
p->parr = i;
}
//释放空间
free(p->parr); //得先释放结构体成员parr所指向的空间
p->parr = NULL;
free(p); //在释放p,若顺序弄错造成内存泄露
p->parr = NULL;
return 0;
}
说白了就是利用结构体里的指针paar再去开辟一块动态内存空间
代码一比代码二优势的地方在于:
优势 1 :方便内存释放
使用了较少次的malloc,这样使后面的内存释放得到了方便,且也不容易造成内存泄漏
优势 2 :提升性能
连续的内存有益于提⾼访问速度,也有益于减少内存碎⽚。