c中柔性数组

c99中,结构中最后一个元素允许是未知大小的数组,这就叫柔性数组成员。

柔性数组的特点

1.结构中柔性数组前必须至少有一个其他成员

2.sizeof返回的这种结构大小不包括柔性数组的内存

3.包含柔性数组成员的结构用malloc函数进行动态分配,并且分配的内存应该大于结构的大小,以适应柔性数组的预期大小

4.柔性数组在结构体中只能存在一个

下面我们来介绍两种使用柔性数组的方法

法1

接下来是法2

法1的好处

1.如果我们的代码是在一个给别人用的函数中,你在里面做了二次内存分配 ,并把整个结构返回给用户,用户调用free可以释放结构体,但是用户并不知道这个结构体内的成员也需要free,所以你不能指望用户来发现这个事。所以,如果我们把结构体的内存以及其成员要的内存一次性分配好,并返回给用户一个结构体指针,用户做一次free就可以把所有也给释放掉。

2.这样有利于提高访问速度

连续的内存有益于提高访问速度,也有益于减少内存碎片。(其实,我个人觉得也没多高,反正你跑不了要用偏移量的加法来寻址)。

那么今天分享就到这里,谢谢大家!!!

相关推荐
小龙报1 小时前
《算法通关指南C++编程篇 --- 初阶函数递归专题》
c语言·开发语言·c++·算法·创业创新·学习方法·visual studio
星轨初途1 小时前
《数据结构二叉树之堆 —— 优先队列与排序的高效实现(2)(下)》
c语言·开发语言·数据结构·经验分享·笔记·性能优化
Shylock_Mister1 小时前
ARM与x86交叉编译实战排错指南
linux·c语言·arm开发
高山有多高2 小时前
堆应用一键通关: 堆排序 +TOPk问题的实战解析
c语言·数据结构·c++·算法
程序猿追2 小时前
Ascend C编程范式总结:与CUDA的异同对比
c语言·开发语言·算法
晨非辰4 小时前
【数据结构初阶系列】归并排序全透视:从算法原理全分析到源码实战应用
运维·c语言·数据结构·c++·人工智能·python·深度学习
松涛和鸣9 小时前
11.C 语言学习:递归、宏定义、预处理、汉诺塔、Fibonacci 等
linux·c语言·开发语言·学习·算法·排序算法
鑫—萍14 小时前
C/C++精品算法——双指针(1)
c语言·c++·算法
智者知已应修善业16 小时前
【51单片机:两边向中间流水:即两边先点亮然后熄灭,次边的点亮再熄灭,直到最中间的两个点亮再熄灭,然后重复动作。】2023-3-4
c语言·c++·经验分享·笔记·嵌入式硬件·算法·51单片机
Vanranrr18 小时前
车机项目中的 Widget 设计反思:从“能用”到“好用”的改进方向
c语言·c++·架构