柔性数组 柔性数组使用

6. 柔性数组

结构中的最后一个元素允许是未知大小的数组,这就叫做柔性数组成员

struct s1
{
    int num;
    double d;
    int arr[ ];//柔性数组成员
};

struct s2
{
    int num;
    double d;
    int arr[0];//柔性数组成员
}; 

6.1 柔性数组的特点:

1.结构中的柔性数组成员前面必须至少一个其他成员
2.sizeof 返回的这种结构大小不包括柔性数组的内存
3.包含柔性数组成员的结构用malloc ()函数进行内存的动态分配,并且分配的内存应该大于结构的大 小,以适应柔性数组的预期大小
struct s3
{
	int num;
	int arr[];//柔性数组大小不算,前面至少有一个其他成员
};
int main()
{
	printf("%d\n",sizeof(struct s3));//4
}

6.2 柔性数组的使用

struct s3
{
	int num;
	int arr[];//柔性数组大小不算,前面至少有一个其他成员
};
int main()
{
	struct s3* ps = (struct s3*)malloc(sizeof(struct s3) + 40);//希望数组里放10个整型
	ps->num = 100;
	for (int i = 0; i < 10; i++)
	{
		ps->arr[i] = i;
	}
	for (int i = 0; i < 10; i++)
	{
		printf("%d ",ps->arr[i]);//0 1 2 3 4 5 6 7 8 9
	}
	free(ps);
	ps = NULL;
}
struct s3
{
	int num;
	int arr[];//柔性数组大小不算,前面至少有一个其他成员
};
int main()
{
	struct s3* ps = (struct s3*)malloc(sizeof(struct s3) + 40);//希望数组里放10个整型
	if (ps == NULL)
	{
		perror("relloc\n");
		return 1;
	}
	ps->num = 100;
	for (int i =0; i < 10; i++)
	{
		ps->arr[i] = i;
	}
    //扩容
	struct s3* ptr = (struct s3*)realloc(ps, sizeof(struct s3) + 80);//希望数组里放20个整型
	if (ptr == NULL)
	{
		perror("relloc\n");
		return 1;
	}
	else
	{
		ps = ptr;
	}
	for (int i = 10; i < 20; i++)
	{
		ps->arr[i] = i;
	}
	for (int i = 0; i <20; i++)
	{
		printf("%d ",ps->arr[i]);//打印0-19
	}	
	free(ps);
	ps = NULL;
}

6.3 柔性数组的优势

第一个好处是: 方便内存释放 如果我们的代码是在一个给别人用的函数中,你在里面做了二次内存分配,并把整个结构体返回给用户。用户调用free 可以释放结构体,但是用户并不知道这个结构体内的成员也需要 free, 所以如果我们把结构体的内存以及其成员要的内存一次性分配好了,并返回给用户一个结构体指针,用户做一次free 就可以把所有的内存也给释放掉
第二个好处是: 这样有利于访问速度, 连续的内存有益于提高访问速度,也有益于减少内存碎片
//功能和上面代码完全相同,上面代码有2个好处
struct s4
{
    int num;
    int*arr;
};
int main()
{
    struct s4*ps=(struct s4*)malloc(sizeof(struct s4));
    if(ps==NULL)return 1;
    ps->arr=(int*)malloc(40);
    if(ps->arr==NULL)
    {
        free(ps);
        ps=NULL;
        return 1;
    }
    //使用
    //释放
    free(ps->arr);
    ps->arr=NULL;
    free(ps);
    ps=NULL;
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值