析构函数virtual与非virtual

当父类不含virtual析构函数时,其继承的子类对象由父类指针被删除,那么结果未有定义,即实际执行时通常发狠的是对象的子类成分并没有销毁。

#include <iostream>
using namespace std;

struct A
{
   /* virtual ~A() {cout<<"~A()\n";}*/
	  ~A() {cout<<"~A()\n";}
};

struct B: public A
{
    ~B() {cout<<"~B()\n";}
};

void main()
{
    A* p = new B;
    delete p;
    system("pause");
}

结果如下: 子类对象并没有被销毁

当父类析构函数带有virtual时,则子类对象可以被销毁。

#include <iostream>
using namespace std;

struct A
{
    virtual ~A() {cout<<"~A()\n";}
	  /*~A() {cout<<"~A()\n";}*/
};

struct B: public A
{
    ~B() {cout<<"~B()\n";}
};

void main()
{
    A* p = new B;
    delete p;
    system("pause");
}

结论:带多态性质的父类需要声明一个virtual析构函数,如果类带有任何virtual函数,则其必须拥有一个virtual析构函数。

        如果一个不是做父类(不含有继承),则其不应该声明virtual析构函数。


版权声明:本文为M_Loveward原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。