柔性概念
零长度数组(Arrays of Length Zero)也叫做可变数组/柔性数组。 在c99中,对于结构体中的最后一个成员,可以允许最后一个成员是未知大小的数组,这样的数组就叫做柔性数组。
定义
struct udppkt { struct ethhdr et; struct iphdr ip; struct udphdr udp; unsigned char data[0];//定义零长数组或柔性数组,1.不需要具体的长度。2.不考虑越界 } 或者 struct udppkt { struct ethhdr et; struct iphdr ip; struct udphdr udp; unsigned char data[];//定义零长数组或柔性数组,1.不需要具体的长度。2.不考虑越界 }
特点
特点: 1> 定义的结构体中的柔性数组成员前面必须至少含有一个别的类型的成员;一般柔性数组放到结构体最后;
2>结构体长度,sizeof返回的结构体的大小不包含柔性数组的大小;柔性数组长度为0;
3>包含柔性数组成员的结构体的大小用malloc函数动态分配内存,并且分配的内存大小应该大于结构体的大小,以适应柔性数组的预期大小。
4> 对于长度为0数组, 在申请内存空间时, 采用一次性分配的原则进行;
用途 : 长度为0的数组的主要用途是为了满足需要变长度的结构体
用法 : 在一个结构体的最后, 申明一个长度为0的数组, 就可以使得这个结构体是可变长的. 对于编译器来说, 此时长度为0的数组并不占用空间, 因为数组名本身不占空间, 它只是一个偏移量, 数组名这个符号本身代表了一个不可修改的地址常量。
性能
第一个好处是:方便内存释放
如果我们的代码是在一个给别人用的函数中,你在函数中做了两次内存分配,并把整个结构体返回给用户。用户调用free可以释放结构体,但是用户并不知道这个结构体内的成员也需要free,所以你不能指望用户来发现这个事。所以,如果我们把结构体的内存以及其成员要的内存一次性分配好了,并返回给用户一个结构体指针,用户做一次free就可以把所有的内存
也给释放掉。
第二个好处是:有利于访问速度.
连续的内存有益于提高访问速度,也有益于减少内存碎片。