我严重误解了c ++构造函数。在下面显示的代码中,我试图在MyClass1中初始化aVar。该代码生成以下错误(也显示在代码中):
(1)在当前作用域中已经声明了“ aVar2”
(2)引用变量“ var”需要初始化
有人可以指出我正确的方向。
谢谢。
class Myclass1
{
public:
Myclass1(int * var1);
Myclass1(void);
private:
int * aVar;
};
class Myclass2
{
public:
Myclass2(int * var2);
private:
Myclass1 myclass1;
};
class Myclass3
{
public:
Myclass3(void);
private:
Myclass2 myclass2;
int var;
};
Myclass1::Myclass1(int * aVar1)
{
aVar = aVar1;
}
Myclass2::Myclass2(int * aVar2)
{
//ERROR: "aVar2" has already been declared in the current scope
Myclass1(aVar2);
}
Myclass3::Myclass3(void)
{
var = 2;
//ERROR: reference variable "var" requires an initializer
Myclass2(&var);
}
int main(void)
{
Myclass3 myFinalClass;
return 0;
}
最佳答案
Myclass1(aVar2);
这是不对的,因为成员变量名称为
myclass1
,而且您还必须像这样分配它:myclass1 = aVar2
。在这里,编译器认为您只是在尝试创建一个与参数名称相同的新Myclass1
对象。这是您需要的:Myclass2::Myclass2(int * aVar2) : myclass1(aVar2) { }
Myclass3::Myclass3() : myclass2(&var) { }
要知道,初始化列表总是比初始化构造函数主体中的成员更好。参见the C++ FAQ on this。除了提供统一的语法外,它可能也会更快。因此,您的
Myclass1
构造函数将采用以下形式更好:Myclass1::Myclass1(int * aVar1) : aVar(aVar1) { }
关于c++ - 调用C++构造函数问题,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/33106574/