其他分享
首页 > 其他分享> > c – 在其他类构造函数中使用参数化构造函数

c – 在其他类构造函数中使用参数化构造函数

作者:互联网

我担心这是一个非常基本的问题,然而,我还没能解决它.

我有一个A班

// classA.h
...

class ClassA {
    public:
        ClassA();
        ClassA(int foo);
    private:
        int _foo;

    ...

}

// classA.cpp

ClassA::ClassA() {
    _foo = 0;
}

ClassA::ClassA(int foo) {
    _foo = foo;
}

...

第二个类B在构造函数中使用类A的实例:

// classB.h
...

#include "classA.h"

#define bar 5

class ClassB {
    public:
        ClassB();
    private:
        ClassA _objectA;

    ...

}

// classB.cpp

ClassB::ClassB() {
    _objectA = ClassA(bar);
}

...

请注意,从不使用类A的默认构造函数.事实上,在我的真实世界用例中,使用任何类型的默认构造函数都没有意义,因为必须动态分配_foo.

但是,如果我删除默认构造函数,编译器将返回错误:

no matching function for call to ‘ClassA::ClassA()’

有没有办法在类B中使用类A的实例作为对象而不为类A定义默认构造函数?怎么做?

解决方法:

使用ClassA的默认构造函数.使用它初始化ClassB的_objectA,然后为其分配ClassA(bar).

您可以使用constructor initializer lists解决您的问题:

ClassB::ClassB() : _objectA(bar)
{}

标签:c,constructor,instance-variables,default-constructor
来源: https://codeday.me/bug/20190823/1702372.html