![](/img/trans.png)
[英]Object with parameterized constructor as parameter for another classes constructor
[英]use parameterized constructor in other classes constructor
我担心这是一个非常基本的问题,然而,我还没能解决它。
我有一个class 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;
}
...
第二个class B
在构造函数中使用class A
的实例:
// classB.h
...
#include "classA.h"
#define bar 5
class ClassB {
public:
ClassB();
private:
ClassA _objectA;
...
}
// classB.cpp
ClassB::ClassB() {
_objectA = ClassA(bar);
}
...
请注意,从不使用class A
的默认构造函数。 事实上,在我的真实世界用例中,使用任何类型的默认构造函数都没有意义,因为必须动态分配_foo
。
但是,如果我删除默认构造函数,编译器将返回错误:
调用'ClassA :: ClassA()'没有匹配函数
有没有办法在class B
使用class A
的实例作为对象而不为class A
定义默认构造函数? 怎么做?
使用ClassA
的默认构造函数。 使用它初始化ClassB
的_objectA
, 然后为其分配ClassA(bar)
。
您可以使用构造函数初始化列表来解决您的问题:
ClassB::ClassB() : _objectA(bar)
{}
写吧
ClassB::ClassB() : _objectA(bar)
{
}
问题是当执行ClassB
的构造函数的主体时,数据成员_objectA
已经构造并且在主体内部使用了复制赋值运算符
ClassB::ClassB() {
_objectA = ClassA(bar);
^^^^^^^^^^^^^^^^^^^^^^^^
}
因此,您可以删除ClassA
的默认构造函数。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.