条款14: 确定基类有虚析构函数

条款14: 确定基类有虚析构函数
对于这个问题来说,我想直接举这个例子就比较好解释了。
class enemytarget {
public:
enemytarget() { ++numtargets; }
enemytarget(const enemytarget&) { ++numtargets; }
~enemytarget() { --numtargets; }

static size_t numberoftargets()
{ return numtargets; }

virtual bool destroy(){return 0;}; // 摧毁enemytarget对象后
// 返回成功

private:
static size_t numtargets; // 对象计数器
};

size_t enemytarget::numtargets=0;

class enemytank: public enemytarget {
public:
enemytank() { ++numtanks; }

enemytank(const enemytank& rhs)
: enemytarget(rhs) //基类构造函数
{ ++numtanks; }

~enemytank() { --numtanks; }

static size_t numberoftanks()
{ return numtanks; }

virtual bool destroy(){return 0;};

private:
static size_t numtanks; // 坦克对象计数器
};

size_t enemytank::numtanks=0;

int main()
{
enemytarget *targetptr = new enemytank;
cout<<"targetptr: "<<targetptr->numberoftargets()<<endl;
cout<<"targetptr: "<<enemytank::numberoftanks()<<endl;
delete targetptr;
cout<<"targetptr: "<<targetptr->numberoftargets()<<endl;
cout<<"targetptr: "<<enemytank::numberoftanks()<<endl;

return 0;
}

结果:
targetptr: 1
targetptr: 1
targetptr: 0 //只调用基类的析构函数
targetptr: 1
Press any key to continue



看吧,DELETE时,派生类中的坦克数量没被释放。解决的方法很简单,把基类的析构函数设为虚函数。那么语意就变为,让派

生类去定制自己的行为。所以说在定制基类时,对其的析构函数都要指定虚函数。
那么是否要对每个基类都申请虚拟函数呢?
申明一个虚拟函数花费的代价是产生一个32位的指针,这是否会让它变得不可移植了呢?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值