C语言 柔性数组

文章目录

  • 定义
  • 使用

定义

C语言中的柔性数组(Flexible Array)是一种特殊的数组类型,它的长度可以在运行时动态确定。柔性数组通常用于结构体的最后一个成员,用于表示可变长度的数据。

struct Example {
    int length;
    int data[]; // 柔性数组
};

特性:

  1. 结构中的柔性数组成员前面必须至少一个其他成员。
  2. sizeof 返回的这种结构大小不包括柔性数组的内存。
  3. 包含柔性数组成员的结构用malloc ()函数进行内存的动态分配,并且分配的内存应该大于结构的大小,以适应柔性数组的预期大小。即如果使用malloc一次性分配空间,结构体总空间满足: maollc总空间 = 其他结构体内成员空间 + 柔性数组空间 ;

使用

方法1 : 直接对整个接结构体使用动态内存分配函数 。 分配内存满足 maollc总空间 = 其他结构体内成员空间 + 柔性数组空间 ;



typedef struct st_type
{
 int i;
 int a[0];//柔性数组成员
}type_a;


int i = 0;
type_a *p = (type_a*)malloc(sizeof(type_a)+100*sizeof(int));
p->i = 100;
for(i=0; i<100; i++)
{
 p->a[i] = i;
}
free(p);

方法2 :分别对结构体内的每个成员使用动态分配内存函数,值得注意的是,此方法释放内存时,也要分别释放 ;

typedef struct st_type
{
 int i;
 int *p_a;
}type_a;


type_a *p = (type_a *)malloc(sizeof(type_a));
p->i = 100;
p->p_a = (int *)malloc(p->i*sizeof(int));

for(i=0; i<100; i++)
{
 p->p_a[i] = i;
}

//释放空间
free(p->p_a);
p->p_a = NULL;
free(p);
p = NULL;

你可能感兴趣的:(c语言,柔性数组,个人学习)