结论一:转载自 https://www.cnblogs.com/huhuuu/archive/2013/12/01/3453063.html
析构函数的作用与构造函数正好相反,是在对象的生命期结束时,释放系统为对象所分配的空间,即要撤消一个对象。
用对象指针来调用一个函数,有以下两种情况:
-
如果是虚函数,会调用派生类中的版本。(在有派生类的情况下)
-
如果是非虚函数,会调用指针所指类型的实现版本。
析构函数也会遵循以上两种情况,因为析构函数也是函数嘛,不要把它看得太特殊。 当对象出了作用域或是我们删除对象指针,析构函数就会被调用。
当派生类对象出了作用域,派生类的析构函数会先调用,然后再调用它父类的析构函数, 这样能保证分配给对象的内存得到正确释放。
但是,如果我们删除一个指向派生类对象的基类指针,而基类析构函数又是非虚的话, 那么就会先调用基类的析构函数(上面第2种情况),派生类的析构函数得不到调用。
结论二:转载自 http://blog.csdn.net/fenghaibo00/article/details/6692281
1.无论父类与子类的析构函数是否为virtual,子类的析构函数都会调用基类的析构函数;
2、如果父类与子类的析构函数都不是virtual,用一个父类的指针指向子类类型的new的对象时,delete直接调用父类的析构函数,这是编译时刻就决定的,造成内存泄漏;
3、如果父类的析构函数为虚函数,用一个父类的指针指向子类类型的new的对象时,delete时,这时由于通过虚函数表调用析构函数,而虚函数表中的地址是构造时写入
的,是子类的析构函数地址,结合一个结论,子类和父类的析构函数都会被调用,不会造成内存泄漏。