c++继承默认构造函数
c++ inheritance default constructor
class A{
public:
A(){ cout << “A ctor” << endl; }//default A constructor
A(const A& a){ cout <<“A copy ctor”<< endl; }//copy constructor
virtual ~A(){ cout <<“A dtor”<< endl; }//destructor
virtual void foo(){ cout <<”A foo()” << endl; }
virtual A& operator=(const A& rhs){ cout << “A op=” << endl; }//operator
};
class B:public A{
public:
B(){ cout <<“B ctor”<< endl; }//default B constructor
virtual ~B(){ cout <<”B dtor”<< endl; }//destructor
virtual void foo(){ cout <<”B foo()”<< endl; }
protected:
A mInstanceOfA;
};
A foo(A& input){
input.foo();
return input;
}
Int main(){
B myB;
B myOtherB;
A myA;
myOtherB=myB;
myA=foo(myOtherB);
}
程序打印:
A ctor
A ctor
B ctor
A ctor
A ctor
B ctor
A ctor
A op=
A op=
B foo()
A copy ctor
A op=
A dctor
为什么在打印"B "前打印2次"A "为什么在程序末尾打印"A copy tor","A op=","A tor"??*/
在B之前打印A两次,因为:
- 第一次是因为B派生自A,所以它是基类 的实例化
- 第二次是因为B 包含 A的实例作为成员变量。因此,在调用B的构造函数之前,它也被实例化了。
最后,输出A的复制构造函数、赋值操作op和析构函数,因为foo()按值返回A的实例,因此需要将其复制到目的地。
另外,你可能想把你的问题的格式和问得更好一点,否则有人会反对你的问题。
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 为什么不调用移动构造函数?(默认情况下只有构造器,没有别的)
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 基类中的默认析构函数禁用子类中的移动构造函数(如果有成员)
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 构造函数默认公共和私有变量
- 类模板构造函数默认参数
- 构造函数默认参数
- C++模板构造函数默认参数
- 在c++中设置构造函数默认值
- c++构造函数默认参数
- C++构造函数默认值头文件