关于柔性数组

以前确实没关注过这个问题,一直都是直接定义固定长度的数组,尽量减少指针的操作。

柔性数组主要是再结构体里面定义一个长度为0的数组,这里和定义一个指针式存在明显去别的。定义一个指针会占用内存,但是定义一个长度为0的数组不会占用空间。

以下具体的使用例程:

objectivec 复制代码
//结构体定义
strcut Test
{
    int number;
    char buf[0];    //柔性数组
};

int main(void)
{
    
    struct Test* ptr = null;        //创建指针
     /*
       动态分配大小,这里是柔性数组实现的关键部分
       根据上面的描述,结构体实际上空间只有4个Byte
       后续增加的空间,就是柔性数组的大小,实现不定长数组。
     */
    ptr = (struct Test*)malloc(sizeof(struct Test) + 40);
    ptr->number = 20;
    if(ptr != null)
    {
         printf("分配成功\n");
         for(int i = 0;i < ptr->number)
         {
            ptr->buf[i] = i;
            printf("%d" ,ptr->buf[i]);
         }
         printf("测试完毕\n");
         //释放
         free(ptr);
         //消除野指针
         ptr = null;
    }
    else
    {
        printf("分配失败\n");
    }
    return 0;
}

总体来说,柔性数组具有极大的灵活性,主要是用作底层接口实现,对外只需要使用一个指针实现不定长数组,减少代码的风险。

相关推荐
多打代码28 分钟前
2025.09.05 用队列实现栈 & 有效的括号 & 删除字符串中的所有相邻重复项
python·算法
j_xxx404_2 小时前
数据结构:栈和队列力扣算法题
c语言·数据结构·算法·leetcode·链表
南莺莺2 小时前
假设一个算术表达式中包含圆括号、方括号和花括号3种类型的括号,编写一个算法来判别,表达式中的括号是否配对,以字符“\0“作为算术表达式的结束符
c语言·数据结构·算法·
THMAIL2 小时前
深度学习从入门到精通 - 神经网络核心原理:从生物神经元到数学模型蜕变
人工智能·python·深度学习·神经网络·算法·机器学习·逻辑回归
野犬寒鸦2 小时前
力扣hot100:旋转图像(48)(详细图解以及核心思路剖析)
java·数据结构·后端·算法·leetcode
墨染点香3 小时前
LeetCode 刷题【61. 旋转链表】
算法·leetcode·职场和发展
一枝小雨3 小时前
【OJ】C++ vector类OJ题
数据结构·c++·算法·leetcode·oj题
Tisfy3 小时前
LeetCode 3516.找到最近的人:计算绝对值大小
数学·算法·leetcode·题解
自信的小螺丝钉3 小时前
Leetcode 206. 反转链表 迭代/递归
算法·leetcode·链表
黑色的山岗在沉睡4 小时前
LeetCode 189. 轮转数组
java·算法·leetcode