1)第一个代码
class A
{
public:
int i;
int b;
A(int temp){
i=temp;
A();
b=0;
}
A(){
b=0;
}
void display(){
printf("%d %d\n",i,b);//1 0
}
};
int main(){
A Aobj(1);
Aobj.display();
return 0;
}
输出:1 0
2)第二个代码
class A
{
public:
int i;
int b;
A(int temp) : i(temp), A(), b(0) {}//Error
A() : b(0) {}
void display(){
printf("%d %d\n",b,i);
}
};
int main()
{
A Aobj(1);
Aobj.display();
return 0;
}
我期望这两个代码将显示相同的行为,并且会产生错误,因为不允许从同一类中的另一个构造函数调用一个构造函数。 这不是 C++11。
那么为什么使用初始化列表会产生影响呢? 我在 g++ 4.3.4 中编译了这些代码。
最佳答案
A();
没有按照您的想法进行操作。
将其替换为 double();
或 char();
或任何其他类型。请注意,它有效。
您所做的就是创建该类型的一个匿名附加实例,然后将其丢弃。它对 this
没有任何影响,并且不会做您认为它会做的事情。
初始化列表在 C++11 中按照您期望的方式工作。
关于c++ - 从同一类中的另一个构造函数调用一个构造函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13328118/