码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2015-08-16 21:25:09      阅读:222      评论:0      收藏:0      [点我收藏+]

标签:

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

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

在linux gcc下测试一下
技术分享
运行结果为
技术分享
结构体中,最后一个元素是一个数组,而且是一个未定义长度的数组,
技术分享
运行结果与理论一致,
这个有点像c++中类的成员函数,成员函数也是不占用类空间大小的。
那么这个柔性数组,存在的作用有什么。

如果说想要获得一段内存空间,我们可以像上面讲的那样,使用数组,但是实现上面的功能,同样可以用指针来实现。
如下
技术分享
运行结果
技术分享
下面一段解释:

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

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

版权声明:本文为博主原创文章,未经博主允许不得转载。

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

标签:

原文地址:http://blog.csdn.net/u010442328/article/details/47706437

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!