什么是柔性数组?
也许你从来没有听说过柔性数组(flexible array)这个概念,但是它确实是存在的。
C99 中,结构中的最后一个元素允许是未知大小的数组,这就叫做『柔性数组』成员。
1. typedef struct st_type 2. { 3. int i; 4. int a[0];//柔性数组成员 5. }type_a;
有些编译器会报错无法编译可以改成:
1. typedef struct st_type 2. { 3. int i; 4. int a[];//柔性数组成员 5. }type_a;
结构中的柔性数组成员前面必须至少一个其他成员。
sizeof 返回的这种结构大小不包括柔性数组的内存。
包含柔性数组成员的结构用malloc ()函数进行内存的动态分配,并且分配的内存应该大于结构的大
小,以适应柔性数组的预期大小。
1. //code1 2. typedef struct st_type 3. { 4. int i; 5. int a[0];//柔性数组成员 6. }type_a; 7. printf("%d\n", sizeof(type_a));//输出的是4
柔性数组的使用
1. //代码1 2. int i = 0; 3. type_a *p = (type_a*)malloc(sizeof(type_a)+100*sizeof(int)); 4. //业务处理 5. p->i = 100; 6. for(i=0; i<100; i++) 7. { 8. p->a[i] = i; 9. } 10. free(p);
这样柔性数组成员a,相当于获得了100个整型元素的连续空间
柔性数组的优势
上述的 type_a 结构也可以设计为:
1. //代码2 2. typedef struct st_type 3. { 4. int i; 5. int* p_a; 6. }type_a; 7. type_a* p = (type_a*)malloc(sizeof(type_a)); 8. p->i = 100; 9. p->p_a = (int*)malloc(p->i * sizeof(int)); 10. //业务处理 11. for (i = 0; i < 100; i++) 12. { 13. p->p_a[i] = i; 14. } 15. //释放空间 16. free(p->p_a); 17. p->p_a = NULL; 18. free(p); 19. p = N;
上述 代码1 和 代码2 可以完成同样的功能,但是 方法1 的实现有两个好处:
第一个好处是:方便内存释放
如果我们的代码是在一个给别人用的函数中,你在里面做了二次内存分配,并把整个结构体返回给
用户。用户调用free可以释放结构体,但是用户并不知道这个结构体内的成员也需要free,所以你
不能指望用户来发现这个事。所以,如果我们把结构体的内存以及其成员要的内存一次性分配好
了,并返回给用户一个结构体指针,用户做一次free就可以把所有的内存也给释放掉。
第二个好处是:这样有利于访问速度.
连续的内存有益于提高访问速度,也有益于减少内存碎片。(其实,我个人觉得也没多高了,反正
你跑不了要用做偏移量的加法来寻址)
扩展阅读:
文章知识点与官方知识档案匹配,可进一步学习相关知识