C++中的虚析构函数的作用

  事实上,虚析构函数,就是虚的析构函数,也就是析构函数具有了虚函数的性质。

在C++开发中,用来做基类的类的析构函数一般都是虚函数,为什么要这样做,下面来进行以下说明:

下面程序中定义两个类,公有继承:

class ClxBase
{
public:
    ClxBase() {};
    virtual ~ClxBase() {};

    virtual void DoSomething() 
{ 
cout << "Do something in class ClxBase!" << endl; 
};
};

class ClxDerived : public ClxBase
{
public:
    ClxDerived() {};
    ~ClxDerived() 
{ 
cout << "Output from the destructor of class ClxDerived!" << endl;
 }; 

    void DoSomething() 
{ 
cout << "Do something in class ClxDerived!" << endl; 
};
};

主程序部分代码:

ClxBase *pTest = new ClxDerived;
pTest->DoSomething();
delete pTest;

程序运行结果如下:

Do something in class ClxDerived!
Output from the destructor of class ClxDerived!

 这个很简单,非常好理解。但是,如果把类ClxBase析构函数前的virtual去掉,输出结果就发生变化了。

改变之后结果如下:

Do something in class ClxDerived!

也就是说,类ClxDerived的析构函数根本没有被调用!一般情况下类的析构函数里面都是释放内存资源,而析构函数不被调用的话就会造成内存泄漏。这种情况下的编程是很危险的。当然,如果在析构函数中做了其他工作的话,那你的所有努力也都是白费力气。


 所以,文章开头的那个问题的答案就是这样做是为了当用一个基类的指针删除一个派生类的对象时,使用了virtual即把析构函数写成虚析构函数,派生类的析构函数会被调用。    
    当然,并不是要把所有类的析构函数都写成虚函数。因为当类里面有虚函数的时候,编译器会给类添加一个虚函数表,里面来存放虚函数指针,这样就会增加类的存储空间。所以,只有当一个类被用来作为基类的时候,才把析构函数写成虚函数。

你可能感兴趣的:(C++)