析构函数总结



1. 基类如果析构函数不为protected,那么最好加上virtual ,让其delete 基类指针 实现多态


2.如果基类析构函数为protected, 可以这样使用:


基类的构造,拷贝构造, 基类& operaotr = (基类指针) 均为protected,  不直接产生、销毁基类。

可以提供一个虚函数去销毁 {delete this:}



效率比纯虚基类效率高一些?



class Base
{
protected:
	Base(){}
	Base(const Base& another){}
	virtual ~Base(){}
	Base operator = (const Base & another);

public:
	virtual void Release()
	{
		delete this;
	}
	virtual void fun() const;

};



void Base::fun() const
{
	cout<<"Base::fun()"<<endl;
}


class Derived :public Base
{
public:
	virtual void fun() const;
};

void Derived::fun() const
{
	cout<<"Derived::fun()"<<endl;
}



int main()
{
	Base* pBase = new Derived();
	assert(pBase);
	pBase->fun();
	pBase->Release();
	pBase = NULL;
	return 0;

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值