我严重误解了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/

10-10 18:51