1)类指针指向本身的对象
Son *xiaoming = new Son;
delete xiaoming;
构造及析构顺序:
父类构造
子类构造;
子类析构;
父类析构。
2)父类指针指向子类对象,,父类析构函数不是虚函数
Father *father = new Son;
delete father.
构造及析构顺序:
父类构造
子类构造;
父类析构。
3)父类指针指向子类对象,,父类析构函数是虚函数
Father *father = new Son;
delete father.
构造及析构顺序:
父类构造
子类构造;
子类析构;
父类析构。
结论:1)如果是自身的类指针指向自身的类对象,不会出现问题。
2)因为存在多态性,如果父类的析构函数不为虚函数,则会出现问题,所以,为增强程序的鲁棒性,则父类的析构函数中设置为虚函数。
virtual Father::~Father(){}
————————————————
以下转载:
版权声明:本文为CSDN博主「黑啤是真的皮」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_44111565/article/details/103308186
为什么需要虚析构函数(超详细)
虚析构函数是为了解决父类指针指向子类对象时,释放子类对象的资源时,释放不完全,造成的内存泄漏问题。
多态
发生多态的条件是,父类指针或引用指向子类对象,虚函数重写。
子类会继承父类对象的所有的成员变量和成员函数(除了构造,析构,拷贝构造和赋值操作运算符)。
分析
发生继承后,子类的成员函数比父类多,所以父类指针无法指向子类的成员变量或者函数。即父类指针无法指向子类的析构函数。
所以会造成子类资源释放不完全,所以我们有两种方法可以解决这个问题。
1.将父类指针强转为子类类型的指针
运行结果
2.将父类的析构函数写为虚析构函数
运行结果