1、什么是柔性数组
普通数组的定义必须要在数组名后的方括号内加上一个“常量”才能使用。但是实际使用的时候经常不能提前知道数组大小,给太大容易造成空间浪费,给太小又不够用。这时,就需要引入柔性数组的概念。
柔性数组不是简单的数组变量,而是一个特殊的自定义的结构体类型。该结构中的最后一个元素允许是未知大小的数组。定义如下
typedef struct st_type
{
int i; //柔性数组前 必须 至少定义一个其他成员
int a []; //柔性数组
//int a[0]; //这样定义柔性数组也可以
}type_a;
2、柔性数组的特点
- 结构中的柔性数组成员前面必须至少一个其他成员。
- sizeof 返回的这种结构大小不包括柔性数组的内存(即便给柔性数组开辟了空间,也是如此)。
- 包含柔性数组成员的结构用 **malloc ()**函数进行内存的动态分配,并且分配的内存应该大于结构的大小,以适应柔性数组的预期大小
看起来很晦涩,因为这是提炼后的结论。建议先看下面的使用案例,再回来看看这三条总结。
3、柔性数组的使用
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<errno.h>
/*
柔性数组的特点:
1.结构中的柔性数组成员前面必须至少一个其他成员。
2.sizeof 返回的这种结构大小不包括柔性数组的内存。
3.包含柔性数组成员的结构用malloc()函数进行内存的动态分配,并且分配的内存应该大于结构的大
小,以适应柔性数组的预期大小
*/
//柔性数组的定义
typedef struct st_type
{
int i; //柔性数组前 必须 至少定义一个其他成员
int a []; //柔性数组
//int a[0]; //这样定义柔性数组也可以
}type_a;
int main()
{
printf("%d\n", sizeof(type_a));
//包含柔性数组成员的 结构 用malloc()函数进行内存的动态分配
//注意:这里是给整个结构体变量开辟空间,而不是单独给结构体里的a指针开辟空间
type_a* ps = (type_a*) malloc(sizeof(type_a) +