柔性数组

 柔性数组

* 柔性数组即数组大小待定的数组
 
* 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的数组,内存布局有兴趣的同学会画一下。

 

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值