应用于不完整类型的变量的成员访问表达式
Member access expression applying to a variable of an incomplete type
请考虑以下代码:
#include <iostream>
struct A
{
static const int b = 42;
static const A *a;
int ca[b]; //OK
int c[a -> b]; //1, ill-formed
};
int main(){ }
演示
在//1
,类类型仍然被认为是不完整的对象类型(相关部分N4296::9.2/2 [class.mem]
)。但是我们不能将类成员访问表达式应用于它。为什么?
您不能解释为什么该程序格式不正确吗?
因为成员访问运算符只能应用于完整类型,如 C++11 5.2.5 [expr.ref]/2 指定的那样:
对于第一个选项(点),第一个表达式应具有完整的类类型。对于第二个选项(箭头),第一个表达式应具有指向完整类类型的指针。
如果你问为什么存在该规则:因为,除非类是完整的,以便成员已被声明,否则没有办法告诉如何解释成员名称。
相关文章:
- 这是关于成员访问规则的正确摘要吗
- 为什么我在空指针错误(链表)中获取成员访问权限
- 成员访问是否在空指针上定义C++?
- C++ IDE 不会推断/自动完成对模板类中的 std::array 下标表达式的成员访问
- 为什么类成员数据必须是静态的才能被模板化类的模板化结构成员访问
- 为什么c++允许成员函数定义中实例的私有成员访问
- C/C++ 包含点的宏参数(成员访问运算符)
- 访问说明符(私有/公共/受保护)如何在内部工作(限制成员访问)?
- 如何将超类的受保护成员访问到其派生类. 如果已在派生类中声明了具有相同名称的函数?
- 内部类私有成员访问和封闭的友好性
- 通过 C++ 中的另一个结构成员访问结构
- 具体化 PRVALUES 成员访问的 decltype 行为不正确
- 常量表达式中的静态成员访问
- XVALUE来自类成员访问表达式
- 未经授权的私有类成员访问会产生编译时错误而不是运行时错误?
- 在 c++ 中,为什么 -> 被称为二进制中缀指针成员访问运算符?
- 如何访问模板参数的成员?“成员访问不完整的类型”
- 不明确的可变参数类成员访问
- C 受保护的成员访问
- 将typeID转换为静态成员访问(C )的命名空间