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;
相关推荐
qeen871 小时前
【数据结构】树的基本概念及存储
c语言·数据结构·c++·学习·
pluviophile_s5 小时前
第18讲:⾃定义类型:结构体
c语言·笔记
꧁细听勿语情꧂7 小时前
向下调整算法,top - k 问题,链式结构二叉树,前中后序遍历
c语言·开发语言·数据结构·算法
SHARK_pssm8 小时前
【数据结构——顺序表】
c语言·数据结构·经验分享·笔记
小柯博客10 小时前
Amazon Kinesis Video Streams C WebRTC SDK 开发实战
c语言·开发语言·网络·stm32·嵌入式硬件·webrtc·yocto
上弦月-编程11 小时前
C语言位运算:从入门到精通
运维·c语言·开发语言·vscode·算法·leetcode·极限编程
minglie111 小时前
c语言面向对象的led
c语言·开发语言
钰珠AIOT11 小时前
什么是句柄,有什么用?适用于什么场景?
c语言·c++
꧁细听勿语情꧂11 小时前
用队列实现栈、用栈实现队列,树、二叉树、满二叉树、完全二叉树,堆、向下向上调整算法、出堆入堆、堆排序
c语言·开发语言·数据结构·算法
legendary_16311 小时前
Type-C手机快充与音频/数据传输的完美融合:多功能转接器解析
c语言·智能手机·音视频