C语言柔性数组的‘美‘

本文详细介绍了C99中柔性数组的概念,其特点包括需要有其他成员、sizeof不包含柔性数组内存、需用malloc分配空间。文章还比较了柔性数组与指针在内存管理和空间效率上的差异,强调了柔性数组在连续内存使用和减少内存碎片方面的优点。
摘要由CSDN通过智能技术生成

目录

柔性数组的使用和概念

柔性数组的特点

 柔性数组与指针的区别

 柔性数组的好处


柔性数组的使用和概念

 

 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)导致内存碎片不断增加,柔性数组的连续相比于指针恰恰减少了内存碎片,有益于充分的使用好内存。

        关于柔性数组的内容需要添砖加瓦的同学,欢迎在下方评论区留言讨论!共同学习!

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值