标签:nested-class c macos clang
我在定义声明它的类之外的内部类时遇到了问题.
struct Base {
struct A {
struct B;
};
struct A::B {
};
};
它编译并与GCC一起工作但在Clang上失败并出现此错误:
innerclass.cpp:6:12: error: non-friend class member 'B' cannot have a qualified name
struct A::B {
~~~^
如果省略最外面的类Base,则代码适用于Clang.
以这种方式定义内部类是不合法的吗?如果是这样,应该怎么做?
平台:
OS X 10.8.3
XCode 4.6.2
Clang Apple LLVM版本4.2(clang-425.0.24)(基于LLVM 3.2svn)
GCC gcc版本4.2.1(基于Apple Inc. build 5658)(LLVM build 2336.11.00)
解决方法:
我担心海湾合作委员会要宽容. C 11标准第9/1段规定,班级名称是:
nested-name-specifier(opt)类名
这意味着限定名称可以用作类的名称.此外,第9/11段的第一部分规定:
If a class-head-name contains a nested-name-specifier, the class-specifier shall refer to a class that was
previously declared directly in the class or namespace to which the nested-name-specifier refers, […]
你确实在A类中声明了B类.但是,同一段的第二部分增加了:
[…] and the class-specifier shall appear in a namespace enclosing the previous declaration. In such cases, the nested-name-specifier of the class-head-name of the definition shall not begin with a
decltype-specifier.
在您的情况下,类指定符struct A :: B {}不出现在命名空间的范围内,而是出现在类的范围内(尝试将struct Base更改为命名空间Base,您将看到Clang接受它).
因此,解决此问题的正确方法是在命名空间范围内定义类,而不是在Base中定义:
// ...
struct Base::A::B
{
};
标签:nested-class,c,macos,clang 来源: https://codeday.me/bug/20190831/1779048.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。