标签:c constructor instance-variables default-constructor
我担心这是一个非常基本的问题,然而,我还没能解决它.
我有一个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
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。