error: flexible array member not at end of struct 柔性数组/可变数组

在C++之中,给定了一个结构定义和一个指向结构的指针,编译器必须能够通过指针偏移的方式访问该结构的任何成员。由于结构中每个成员的位置都取决于其前导成员的数量和类型,因此访问任何结构都需要知道所有前导成员的数量和类型。

在结构体之中,如果是数组为结构体之中最后的成员。这并不违反上述的编译规则。但是,如果flexible array member 出现在了结构体末尾以外的任何位置,则其后的任意成员的位置都将取决于数组中对应的类型的个数,所以编译器禁止将没有定义长度的数组作为结构体的中间成员。

举个栗子:

cpp 复制代码
struct S {
    int a;
    char b[];
    int c;
};

这里由于b成员的长度是不确定的,所以编译器无法通过S的指针推断出成员c的位置,所以编译报错:b不在结构体S的末尾

而我们看如下的结构体就没有编译报错的问题了:

cpp 复制代码
struct S {
    int a;
    int c;
    char d[];
};
相关推荐
Frank_zhou10 小时前
算法-链表实战【删除链表的倒数第 N 个结点】中等
数据结构
王中阳Go12 小时前
从超市收银到航空调度:贪心算法如何破解生活中的最优决策谜题?
java·后端·算法
故事挺秃然13 小时前
中文分词:机械分词算法详解与实践总结
算法·nlp
车队老哥记录生活15 小时前
【MPC】模型预测控制笔记 (3):无约束输出反馈MPC
笔记·算法
地平线开发者15 小时前
BEV 感知算法评价指标简介
算法·自动驾驶
不过四级不改名67716 小时前
用c语言实现简易c语言扫雷游戏
c语言·算法·游戏
weixin_4196583116 小时前
数据结构之二叉树
java·数据结构
C++ 老炮儿的技术栈17 小时前
手动实现strcpy
c语言·开发语言·c++·算法·visual studio
倔强的石头_18 小时前
【数据结构与算法】利用堆结构高效解决TopK问题
后端·算法
倔强的石头_18 小时前
【数据结构与算法】详解二叉树下:实践篇————通过链式结构深入理解并实现二叉树
后端·算法