c中柔性数组

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

柔性数组的特点

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

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

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

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

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

法1

接下来是法2

法1的好处

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

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

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

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

相关推荐
网域小星球1 小时前
C 语言从 0 入门(二十)|指针进阶:指针数组、数组指针与函数指针
c语言·开发语言·函数指针·数组指针·指针进阶
♛识尔如昼♛1 小时前
C 基础(8) - 函数
c语言·指针·递归·函数
csdn_aspnet2 小时前
C语言 (QuickSort using Random Pivoting)使用随机枢轴的快速排序
c语言·算法·排序算法
爱编码的小八嘎3 小时前
C语言完美演绎7-15
c语言
孬甭_3 小时前
揭开指针的面纱(下)
c语言
计算机安禾3 小时前
【数据结构与算法】第43篇:Trie树(前缀树/字典树)
c语言·开发语言·矩阵·排序算法·深度优先·图论·宽度优先
yashuk3 小时前
C语言入门教程:程序结构与算法举例
c语言·算法·教程·程序设计·开发过程
代码地平线3 小时前
C语言实现堆与堆排序详解:从零手写到TopK算法及时间复杂度证明
c语言·开发语言·算法
学习噢学个屁4 小时前
基于51单片机心率仪—体温心率血氧蓝牙
c语言·单片机·嵌入式硬件·51单片机
千谦阙听4 小时前
数据结构最终章:万字详解排序算法!(内部排序)
c语言·数据结构·学习·算法·排序算法