柔性數組


 柔性數組

* 柔性數組即數組大小待定的數組
 
* 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的數組,內存布局有興趣的同學會畫一下。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM