C语言 柔性数组

文章目录

定义

C语言中的柔性数组(Flexible Array)是一种特殊的数组类型,它的长度可以在运行时动态确定。柔性数组通常用于结构体的最后一个成员,用于表示可变长度的数据。

c 复制代码
struct Example {
    int length;
    int data[]; // 柔性数组
};

特性:

  1. 结构中的柔性数组成员前面必须至少一个其他成员。
  2. sizeof 返回的这种结构大小不包括柔性数组的内存。
  3. 包含柔性数组成员的结构用malloc ()函数进行内存的动态分配,并且分配的内存应该大于结构的大小,以适应柔性数组的预期大小。即如果使用malloc一次性分配空间,结构体总空间满足: maollc总空间 = 其他结构体内成员空间 + 柔性数组空间 ;

使用

方法1 : 直接对整个接结构体使用动态内存分配函数 。 分配内存满足 maollc总空间 = 其他结构体内成员空间 + 柔性数组空间 ;

c 复制代码
typedef struct st_type
{
 int i;
 int a[0];//柔性数组成员
}type_a;


int i = 0;
type_a *p = (type_a*)malloc(sizeof(type_a)+100*sizeof(int));
p->i = 100;
for(i=0; i<100; i++)
{
 p->a[i] = i;
}
free(p);

方法2 :分别对结构体内的每个成员使用动态分配内存函数,值得注意的是,此方法释放内存时,也要分别释放 ;

c 复制代码
typedef struct st_type
{
 int i;
 int *p_a;
}type_a;


type_a *p = (type_a *)malloc(sizeof(type_a));
p->i = 100;
p->p_a = (int *)malloc(p->i*sizeof(int));

for(i=0; i<100; i++)
{
 p->p_a[i] = i;
}

//释放空间
free(p->p_a);
p->p_a = NULL;
free(p);
p = NULL;
相关推荐
皮皮哎哟9 分钟前
数据结构:从队列到二叉树基础解析
c语言·数据结构·算法·二叉树·队列
一匹电信狗17 分钟前
【高阶数据结构】并查集
c语言·数据结构·c++·算法·leetcode·排序算法·visual studio
进击的小头19 分钟前
设计模式组合应用:传感器数据采集与处理系统
c语言·设计模式
日拱一卒——功不唐捐37 分钟前
01背包(C语言)
c语言
Hello World . .1 小时前
数据结构:二叉树(Binary tree)
c语言·开发语言·数据结构·vim
范纹杉想快点毕业1 小时前
嵌入式实时系统架构设计:基于STM32与Zynq的中断、状态机与FIFO架构工程实战指南,基于Kimi设计
c语言·c++·单片机·嵌入式硬件·算法·架构·mfc
划破黑暗的第一缕曙光2 小时前
[数据结构]:6.二叉树链式结构的实现2
c语言·数据结构·二叉树
水饺编程2 小时前
第4章,[标签 Win32] :文本尺寸的度量
c语言·c++·windows·visual studio
浅念-2 小时前
C语言——自定义类型:结构体、联合体、枚举
c语言·开发语言·数据结构·c++·笔记·学习·html
mirror_zAI2 小时前
C语言中的sscanf用法详解
c语言·开发语言