我最近在Danny Kalev的文章了解新的c++ 11初始化表单中发现了一段有趣的代码:
class C
{
string s("abc");
double d=0;
char * p {nullptr};
int y[5] {1,2,3,4};
public:
C();
};
行string s("abc");
对我来说似乎很可疑。我认为在类中初始化成员时不允许使用构造函数。这段代码(简化为class C { string s("abc");
}; ')不能用
- clang 3.6.1(编译器参数为
-std=c++11 -Wall -Wextra -Werror -pedantic-errors
) - g++ 5.1.0(编译器参数相同:
-std=c++11 -Wall -Wextra -Werror -pedantic-errors
) - vc++ 18.00.21005.1(编译器参数为
/EHsc /Wall /wd4514 /wd4710 /wd4820 /WX /Za
) - vc++ 19.00.22929.0(编译器参数由服务:
/EHsc /nologo /W4 /c
预定义)
我是对的,这篇文章有错误吗?
我是对的,这篇文章有错误吗?
是的,这是文章中的一个错误。
数据成员声明中只允许使用大括号或等号初始化式。d
、p
、y
初始化正确,s
不正确。这样做的理由是,使用表达式列表会使声明与函数声明产生歧义,并且还会导致与类体中的名称查找冲突。
来自Bjarne Stroustrup的例子:
class A {
public:
A() {}
A(int a_val) : a(a_val) {}
A(D d) : b(g(d)) {}
int a = 7;
int b = 5;
private:
HashingFunction hash_algorithm{"MD5"}; // Cryptographic hash to be applied to all A instances
std::string s{"Constructor run"}; // String indicating state in object lifecycle
};