C++:子类与父类构造与析构的调用时机

   日期:2020-08-31     浏览:186    评论:0    
核心提示:文章目录一、引言二、代码一、引言构造子类对象时,先调用父类构造函数,再调用子类构造函数(构造函数没有虚函数这一说)析构子类对象时,先调用子类析构函数,再调用父类析构函数(无论父类的析构函数是否为虚函数)析构子类构造的父类对象时,若父类是虚函数,则先调用子类析构函数,再调用父类析构函数析构子类构造的父类对象时,若父类不是虚函数,则只调用父类析构函数二、代码#include #include #include

文章目录

  • 一、引言
  • 二、代码

一、引言

  • 构造子类对象时,先调用父类构造函数,再调用子类构造函数(构造函数没有虚函数这一说)
  • 析构子类对象时,先调用子类析构函数,再调用父类析构函数(无论父类的析构函数是否为虚函数)
  • 构造子类构造的父类对象时,先调用父类构造对象,再调用子类构造对象(构造函数没有虚函数这一说)
  • 析构子类构造的父类对象时,若父类是虚函数,则先调用子类析构函数,再调用父类析构函数
  • 析构子类构造的父类对象时,若父类不是虚函数,则只调用父类析构函数

二、代码

#include <algorithm>
#include <iostream>
#include <fstream>

using namespace std;
fstream fout("test.txt", ios::app);
//A是一个父类 , 析构函数不是虚函数
class A
{
public:
	A()
	{
		fout << " A constructor" << endl;
	}
	~A()
	{
		fout << " A destructor" << endl;
	}
};

//B是A的子类
class B : public A
{
public:
	B()
	{
		fout << " B constructor" << endl;
	}
	~B()
	{
		fout << " B destructor" << endl;
	}
};

//C是一个父类 , 析构函数是虚函数
class C
{
public:
	C()
	{
		fout << " C constructor" << endl;
	}
	virtual ~C()
	{
		fout << " C destructor" << endl;
	}
};

//D是C的子类
class D : public C
{
public:

	D()
	{
		fout << " D constructor" << endl;
	}
	~D()
	{
		fout << " D destructor" << endl;
	}
};
int main()
{
	B * b = new B();//先调用父类A的构造方法,然后调用子类B的构造方法
	delete b;//删除子类,这时候会先调用子类B的析构函数,再调用父类A的析构函数
	fout << "-----------------------------" << endl << endl;
	A *a = new B();//用子类B构造一个父类A的对象 先调用父类A的构造方法,然后调用子类B的构造方法
	delete a;//删除父类,这时候由于A的析构函数不是虚函数,所以直接调用父类A的构造方法,不会调用子类B的构造方法
	fout << "-----------------------------" << endl << endl;


	D * d = new D();//先调用父类C的构造方法,然后调用子类D的构造方法
	delete d;//删除子类,这时候会先调用子类D的析构函数,再调用父类C的析构函数
	fout << "-----------------------------" << endl << endl;
	C *c = new D();//同理,先调用父类C的构造方法,然后调用子类D的构造方法
	delete c;//删除父类,这时候由于C的析构函数是虚函数,所以直接先调用子类D的析构函数,再调用父类C的析构函数

	system("pause");
	return 0;
}

运行结果:

参考:
参考1

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服