C中柔性数组(flexible array)的学习

首先看看什么是柔性数组
C99中,结构中的最后一个元素允许是未知大小的数组,这就叫做柔性数组成员,但结构中的柔性数组成员前面必须至少一个其 他成员。柔性数组成员允许结构中包含一个大小可变的数组。sizeof返回的这种结构大小不包括柔性数组的内存。包含柔性数组成员的结构用malloc ()函数进行内存的动态分配,并且分配的内存应该大于结构的大小,以适应柔性数组的预期大小。
基本模型为

typedef struct st_type
{
    int nCnt;
    int item[];
}type_a;

在linux gcc下测试一下
C中柔性数组(flexible array)的学习_第1张图片
运行结果为
这里写图片描述
结构体中,最后一个元素是一个数组,而且是一个未定义长度的数组,
C中柔性数组(flexible array)的学习_第2张图片
运行结果与理论一致,
这个有点像c++中类的成员函数,成员函数也是不占用类空间大小的。
那么这个柔性数组,存在的作用有什么。

如果说想要获得一段内存空间,我们可以像上面讲的那样,使用数组,但是实现上面的功能,同样可以用指针来实现。
如下
C中柔性数组(flexible array)的学习_第3张图片
运行结果
这里写图片描述
下面一段解释:

要是为了方便的管理内存缓冲区,如果你直接使用指针而不使用数组,那么,
你在分配内存缓冲区时,就必须分配结构体一次,然后再分配结构体内的指针一次,(而此时分配的内存已经与结构体的内存不连续了,
所以要分别管理即申请和释放)而如果使用数组,那么只需要一次就可以全部分配出来,反过来,释放时也是一样,使用数组,一次释放,
使用指针,得先释放结构体内的指针,再释放结构体。还不能颠倒次序。
其实就是分配一段连续的的内存,减少内存的碎片化。

在网络编程应用方面这种写法也是用的比较多的,具体问题后面再研究。
特别注意这种写法是在c99以后的。

你可能感兴趣的:(编译器,编程之美,编程规范,c/c++)