标签:使用 ar art div 问题 sp on c new
构造函数
virtual析构函数
下面来说一说为多态基类声明virtual析构函数:
在C++中,构造函数不能声时为虚函数,这是因为编译器在构造对象时,必须知道确切类型,才能正确的生成对象,因此,不允许使用动态束定;其次,在构造函数执行之前,对象并不存在,无法使用指向此此对象的指针来调用构造函数,然而,析构函数是可以声明为虚函数;C++明白指出,当derived class对象经由一个base class指针被删除,而该base class带着一个non-virtual析构函数,其结果未有定义---实际执行时通常发生的是对象的derived成分没被销毁掉。
class Derive:public Base
{
public:
Derive(){ std::cout<<"Derive::Derive()"<<std::endl; }
~Derive(){ std::cout<<"Derive::~Derive()"<<std::endl; }
};
int _tmain(int argc, _TCHAR* argv[])
{
Base* pBase = new Derive();
delete pBase;
return 0;
}
输出结果是:
Base::Base()
Derive::Derive()
Derive::~Derive()
Base::~Base()
由结果可以看出,在父类的虚析构函数有自己的实现时,当调用完子类对象的析构函数结束后,还会调用父类的析构函数。而一般的虚函数都是子类覆盖了父类的,调用完子类方法后不会再调用父类的方法。况且虚析构函数也不能想一般的虚函数一样写成纯虚函数的形式。这一切还是由于析构函数的特殊性决定的。
构造和析构函数都有着特别的意义,这是与其它函数不同的,并且在一个类层次中析构函数都会被调用,并且调用顺序是有规定的(文章开头已讲),这些是编译器决定的。因此我们必须给出虚析构函数的函数体以供调用。既然调用顺序已定,父类对象的析构函数总是会被调用,所以就没有被子类覆盖之说了。
标签:使用 ar art div 问题 sp on c new
原文地址:http://www.cnblogs.com/guoxiaoqian/p/3969933.html