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