加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

柔性数组(flexible array)

发布时间:2020-12-15 03:33:59 所属栏目:百科 来源:网络整理
导读:相信好多人都没听过这个概念——柔性数组(flexible array),到底什么是柔性数组呢? 【柔性数组的定义】:结构中最后一个元素允许是未知大小的数组,这就是柔性数组。 柔性数组的使用举例: #include stdio.h #include string.h #include malloc.h typedef

相信好多人都没听过这个概念——柔性数组(flexible array),到底什么是柔性数组呢?

【柔性数组的定义】:结构中最后一个元素允许是未知大小的数组,这就是柔性数组。

柔性数组的使用举例:

#include<stdio.h>

#include<string.h>

#include<malloc.h>

typedef struct c

{

??int a;

??int b[];

}C;

intmain(void)

{

?? C* p =(C *)malloc(sizeof(C)+10*sizeof(int));

???p->a = 0;

?? for(inti=0;i<10;i++)

?? {

????? p->b[i]= i+1;

?? }

?? printf("%dn",sizeof(C));

?? for(inti=0;i<10;i++)

?? {

???????printf("%dn",p->b[i]);

?? }

?? free(p);

?? return 0;

}

这就是柔性数组的使用方法。可以利用?C* p =(C *)malloc(sizeof(C)+10*sizeof(int));来申请内存空间。利用p->b[i]来访问数组中的元素。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读