C语言基础知识--柔性数组

复制代码
//  柔性数组
//  柔性数组的特点:柔性数组的成员数量是动态的.
//  存在于结构体中,最后一个成员,未知的成员数量。
//  特点: 柔性数组前面至少有一个成员,sizeof 计算结构体大小,不包含柔性数组成员。
//  包含柔性数组的结构,用malloc 进行内存的动态分配,并且的内存应该大于结构的大小,以适应柔性数组的预期大小。

// struct S {
//   int a;
//   int b;
//   int c[];  // 未知大小,柔性数组成员 或者写成  int c[0];
// };
//
// int main() { 
//   struct S *ps = (struct S*)malloc(sizeof(struct S) + 10 * sizeof(int));
//   if (ps ==  NULL) {
//      perror("malloc()");
//      return 1;
//   }
//   // 访问
//   ps->a = 10;
//   ps->b = 20;
//   for (int i = 0; i < 10; i++) {
//     ps->c[i] = i+1;
//     printf("%d\n", ps->c[i]);
//   }
//   // 调整大小
//   struct S * newp = (struct S*)realloc(ps, sizeof(struct S) + 20 * sizeof(int));
//   if (newp == NULL)  // 如果调整失败为空
//   {
//      perror("realloc()");
//      newp = NULL;
//      return 1;
//   }
//   for (int i = 10; i < 20; i++) {
//     ps->c[i] = i+1;
//     printf("%d\n", ps->c[i]);
//   }
//   free(ps);
//   ps = NULL;
//   // free(newp);
//   // newp = NULL;
//   return 0;
// }
相关推荐
烬羽29 分钟前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说16 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰19 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术20 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考2 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型