目录
柔性数组的使用和概念
柔性数组的特点
柔性数组与指针的区别
柔性数组的好处
柔性数组的使用和概念
arr[]编译
C99 中,结构中的最后一个元素允许是未知大小的数组,这就叫做『柔性数组』成员。
柔性数组的特点
1、柔性数组成员前必须至少有一个其他成员
2、sizeof返回的这种结构体大小不包含柔性数组的内存
3、包含柔性数组成员的结构体要用malloc来内存开辟,且分配的内存要大于该结构体的大小
证明内存大小不包含柔性数组成员
上面为了演示,当然也少不了内存管理,C语言必须为了防止内存泄漏来判断开辟空间是否失败、栈帧结束前空间手动free释放
struct S {
int a;
int arr[];
};
int main()
{
//使用realloc可以开辟空间,也可以扩容,这里直接演示开辟空间
struct S* ptr1 = NULL;
struct S* ptr2 = realloc(ptr1, sizeof(struct S) + 40);//防止开辟失败,返回值为NULL,赋值ptr1从而导致内存泄漏
//ptr2用来测试
if (ptr2 == NULL)
{
perror("realloc failed");
return 1;
}
//没有问题就赋值
ptr1 = ptr2;
ptr2 = NULL;//*ptr2在栈区(栈帧结束自动销毁),ptr2在堆区(C语言需要free手动释放,防止内存泄露),ptr2赋值给ptr1即可,ptr2置空
//赋值+打印
ptr1->a = 10;
printf("%d\n", ptr1->a);
for (int i = 0; i < 10; ++i)
{
ptr1->arr[i] = i;
}
for (int i = 0; i < 10; ++i)
{
printf("%d ", ptr1->arr[i]);
}
printf("\n");
free(ptr1);//防止内存泄漏
return 0;
}
柔性数组与指针的区别
指针的大小在32位下是4个字节
显然可以看出如果进行像柔性数组那样给结构体变量的空间全部放在堆区,malloc要使用两次
柔性数组的好处
空间内存一次性开辟、一次性修改、一次性释放,空间连续,有益于提高访问速度,而指针重复动态开辟极易引发内存泄漏,由于重复动态内存的开辟(malloc,realloc,alloc)导致内存碎片不断增加,柔性数组的连续相比于指针恰恰减少了内存碎片,有益于充分的使用好内存。
关于柔性数组的内容需要添砖加瓦的同学,欢迎在下方评论区留言讨论!共同学习!