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;
相关推荐
John.Lewis20 分钟前
数据结构初阶(19)外排序·文件归并排序的实现
c语言·数据结构·排序算法
John.Lewis25 分钟前
数据结构初阶(16)排序算法——归并排序
c语言·数据结构·排序算法
wearegogog1231 小时前
C语言中的输入输出函数:构建程序交互的基石
c语言·开发语言·交互
艾莉丝努力练剑13 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
Cx330❀15 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
..过云雨16 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习
谱写秋天17 小时前
在STM32F103上进行FreeRTOS移植和配置(STM32CubeIDE)
c语言·stm32·单片机·freertos
我不是板神17 小时前
程序设计|C语言教学——C语言基础2:计算与控制语句
c语言
基于python的毕设18 小时前
C语言栈的实现
linux·c语言·ubuntu
promising-w1 天前
【嵌入式C语言】六
c语言·开发语言