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[];
};
相关推荐
mit6.82414 小时前
博弈dp|凸包|math分类
算法
Shinom1ya_15 小时前
算法 day 41
数据结构·算法·leetcode
hetao173383715 小时前
2025-10-30 ZYZOJ Star(斯达)模拟赛 hetao1733837的record
c++·算法
无敌最俊朗@15 小时前
C++ 值类别与移动语义详解(精简版)
java·数据结构·算法
lingran__16 小时前
算法沉淀第十一天(序列异或)
c++·算法
一匹电信狗16 小时前
【C++】红黑树详解(2w字详解)
服务器·c++·算法·leetcode·小程序·stl·visual studio
岑梓铭16 小时前
《考研408数据结构》第六章(5.5树的应用)复习笔记
数据结构·笔记·考研·408·ds
不觉晚秋16 小时前
极限挑战之一命速通哈夫曼树
c语言·数据结构··哈夫曼树
寂静山林16 小时前
UVa 11853 Paintball
算法
第七序章17 小时前
【C + +】C++11 (下) | 类新功能 + STL 变化 + 包装器全解析
c语言·数据结构·c++·人工智能·哈希算法·1024程序员节