c.b*_*ear 36 c++ most-vexing-parse visual-studio-2012
我只是想知道为什么这小段代码在Visual Studio中正确编译(并且没有警告).也许结果与GCC和Clang相同,但不幸的是我现在无法测试它们.
struct T {
int t;
T() : t(0) {}
};
int main() {
T(i_do_not_exist);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
cpp*_*ner 43
T(i_do_not_exist);
是一个具有相同含义的对象声明T i_do_not_exist;
.
N4567§6.8[stmt.ambig] p1
语法中涉及表达式语句和声明 s 存在歧义:具有函数式显式类型转换的表达式语句(5.2.3),因为其最左侧的子表达式与第一个声明符以a开头的声明无法区分..在这些情况下,该声明是一个声明.
(
§8.3[dcl.meaning] p6
在具有表格的声明
T D
中D
( D1 )
所含的类型说明符-ID是相同的,所述含有的声明符-ID的声明
T D1
括号不会改变嵌入式声明符id的类型,但它们可以改变复杂声明符的绑定.
mar*_*inj 17
因为它定义了T类型的变量:
http://coliru.stacked-crooked.com/a/d420870b1a6490d7
#include <iostream>
struct T {
int t;
T() : t(0) {}
};
int main() {
T(i_do_not_exist);
i_do_not_exist.t = 120;
std::cout << i_do_not_exist.t;
return 0;
}
Run Code Online (Sandbox Code Playgroud)
上面的例子看起来很愚蠢,但允许这种语法是有原因的.
一个更好的例子是:
int func1();
namespace A
{
void func1(int);
struct X {
friend int (::func1)();
};
}
Run Code Online (Sandbox Code Playgroud)
可能还有其他例子.
归档时间: |
|
查看次数: |
1158 次 |
最近记录: |