C++析构函数一般写成纯虚函数
直接生成的对象,在程序结束时,会自动调用析构函数。
new出来的对象,在手动释放的时候,才会调用析构函数。
Man men;//程序结束时自动调用析构函数
Man* pman = new Man();
delete pman;//delete的时候调用析构函数,如果不delete,不掉用
父类指针指向子类对象的时候,构造函数先调用父类的,析构函数先调用子类的。
父类指针指向子类对象,用new生成子类对象时,delete指针后,系统不会调用子类析构函数。
Human* phman = new Man();
delete phman;//只调用父类的析构函数,不调用子类的析构函数。造成内存泄漏。
return 0;
如何解决:
把父类的虚函数写成虚函数。
class Human {
public:
virtual ~Human();
};//类结尾一定要分号
在public继承中,基类对派生类及其对象的操作,只能影响到从那些基类继承下来的成员。如果想用基类对非继承成员进行操作,则基类的这个函数必须定义成虚函数,析构函数也应该如此。另外,就是基类中的虚函数的虚属性也会被继承给子类,子类中的析构函数也就成为了虚函数,虽然名字不同。delete 父类指针的时候,会调用父类的析构函数。但父类的虚构函数想要调用它子类的析构函数,父类中的析构函数要声名为virtual。c++中为了运行时的多态行为,所调用的成员函数必须得是virtual的。
结论:如果一个类想要做基类,务必要把类的析构函数写成virtual析构函数。只要基类的基类的析构函数是虚函数,就能保住delete指针是,保证运行正确的析构函数版本。
普通类可以不写虚析构函数。但如果是基类,就必须写一个析构函数,而且析构函数必须virtual的
虚函数会增加内存开销,类里面定义虚函数,编译器会增加一个虚函数表,表类存在虚函数的指针。
在子类public继承父类