柔性数组:
C99中,结构中的最后一个元素允许是未知大小的数组,这就叫做柔性数组成员。
有些编译器会报错无法编译,这时可以写成左边这个形式。
struct S struct S
{ {
int n; int n;
int arr[]; int arr[0];//未知大小的,是可以调整大小的
}; };
下面是使用柔性数组的例子:
struct S
{
int n;
int arr[];
};
int main()
{
struct S *ps=(struct*)malloc(sizeof(struct S)+5*sizeof(int));
ps->n=100;
int i=0;
for(i=0;i<5;i++)
{
ps->arr[i]=i;
}
struct S *ptr=realloc(ps,44);
if(ptr!=NULL)
{
ps=ptr;
}
for(i=5;i<10;i++)
{
ps->arr[i]=i;
}
for(i=0;i<10;i++)
{
pintf("%d ',ps->arr[i]);
}
free(ps)
ps=NULL;
return 0;
}
下面是使用指针调整大小的例子:
struct S
{int n;
int *arr;
};
int mian()
{
struct S*ps=(struct S*)malloc(sizeof(struct S));
ps->arr=malloc(5*sizeof(int));
int i=0;
for(i=0;i<5;i++)
{
ps->arr[i]=i;
}
int *ptr=realloc(ps->arr,10*sizeof(int));
if(ptr!=NULL)
{
ps=ptr;
}
for(i=5;i<10;i++)
{
ps->arr[i]=i;
}
for(i=0;i<10;i++)
{
printf("%d ",ps->arr[i]);
}
free(ps->arr);
ps->arr=NULL;
free(ps);
ps=NULL;
return 0;
}
柔性数组的特点:
- 结构中的柔性数组成员前面必须至少一个其他成员
- sizeof返回的这种结构大小不包括柔性数组的内存
- 包含柔性数组成员的结构用malloc函数进行动态内存分配,并且分配内存应该小于结构的大小,以适应柔性数组的预期大小。
优势:
①方便内存释放
②提高访问速度,减少内存碎片
详细介绍可参考视频https://www.bilibili.com/video/BV1454y1v7wA?p=63&share_source=copy_web