柔性数组

来源:互联网 发布:人工智能崛起的例子 编辑:程序博客网 时间:2024/04/28 14:35

柔性数组

* 柔性数组即数组大小待定的数组
 
* C语言中结构体的最后一个元素可以是大小未知的数组
 
* C语言中可以由结构体产生柔性数组
复制代码
#include <stdio.h>#include <malloc.h>typedef struct _soft_array{    int len;    int array[];}SoftArray;int main(){      int i = 0;    SoftArray* sa = (SoftArray*)malloc(sizeof(SoftArray) + sizeof(int) * 10);        sa->len = 10;        for(i=0; i<sa->len; i++)    {        sa->array[i] = i + 1;    }        for(i=0; i<sa->len; i++)    {        printf("%d\n", sa->array[i]);       }        free(sa);        return 0;}
复制代码

 

柔性数组的结构如何只能堆上生成

柔性数组是C99的扩展,简而言之就是一个在struct结构里的标识占位符(不占结构struct的空间)。

声明

typedef struct zero_array{    size_t len;    void * array[0];}zero_array_t;

 

大小

可以用sizeof 看看其大小

printf("%d\n",sizeof(zero_array_t));//CentOS5.6 32 下输出4

zero_array_t 后面跟着一块len的数组,内存布局有兴趣的同学会画一下。

转载自 http://www.cnblogs.com/Daniel-G/archive/2012/12/02/2798496.html

0 0