C++学习笔记51——在构造函数和析构函数中调用虚函数

1,总的原则

一言以蔽之,在构造函数和析构函数的定义体中,其所调用的函数的virtual属性不起作用,没办法使用动态绑定。基类的构造和析构函数中使用的必然是基类的版本;派生类的构造和析构函数中使用的必然是派生类版本。
这么做的原因是,在运行构造或析构函数的时候,对象是不完整的。在基类构造函数或析构函数中,将派生类对象当作基类对象对待。

2,例子

/*******************************************************************/
//  构造函数中调用虚函数
/*******************************************************************/
class Base4
{
public:
	Base4(int ii, int jj) :i(ii), j(jj) { cout << "调用基类的一般构造函数" << endl; }//基类的一般构造函数
	Base4() :i(0), j(5203132) //基类的默认构造函数
	{
		cout << "调用基类的默认构造函数" << endl; 
		hello();//调用虚函数
	}
	Base4(const Base4& b4);//复制构造函数
	Base4& operator=(const Base4& b4);
	virtual ~Base4() { cout << "调用基类的析构函数" << endl; }
	void show_base() { cout << i << "\t" << j<<"\t"; }
	virtual void hello() { cout << "hello 基类" << endl; }
public:
	int i;
private:
	int j;
};

class D4 :public Base4
{
public:
	D4() :k(0) { cout << "调用派生类的默认构造函数" << endl; hello(); }//派生类的默认构造函数,调用虚函数
	D4(int ii, int jj, int kk) :Base4(ii, jj), k(kk) { }//派生类的一般构造函数	
	D4(int kk) : k(kk) {}//派生类的一般构造函数,隐式调用基类的默认构造函数
	D4(const D4& d4);//派生类的复制构造函数
	D4& operator=(const D4&);
	~D4() { cout << "调用派生类的析构函数" << endl; }
	virtual void hello() { cout << "hello 派生类" << endl; }

	int k;
	void show_d() { show_base(); cout << k << endl; }
};

//主函数
int main()
{
	Base4 *pB4 = new D4;
	delete pB4;

	system("pause");
	return 0;
}

执行结果如下:

如前面所说的,在基类的构造函数中调用虚函数的基类版本,在派生类的构造函数中调用虚函数的派生类版本,而不管对象的真实类型。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值