虚析构和纯虚析构
多态使用时,如果子类中有属性开辟到堆区,由于父类指针或引用指向子类对象,因此释放父类指针时会造成无法调用子类中的析构代码,即父类指针在析构时,不会调用子类中析构函数,导致子类如果有堆区属性,出现内存泄露。
解决方法:将父类中的析构函数改为虚析构或者纯虚析构
利用虚析构可以解决 父类指针释放子类对象时不干净的问题。
纯虚析构即令虚析构=0进行声明,然后在类的外部需要具体的实现以防父类中有些堆区数据要释放。这一点纯虚析构与纯虚函数不一样,有了纯虚析构之后(就算没有纯虚函数),这个类也属于抽象类,无法实例化对象。
虚析构和纯虚析构共性:
可以解决父类指针释放子类对象
都需要有具体的函数实现
虚析构和纯虚析构区别:
如果是纯虚析构,该类属于抽象类,无法实例化对象
虚析构语法:
virtual ~类名() {};
纯虚析构语法:
virtual ~类名() = 0;
类名::~类名() {};
(多态的使用,往往是父类的构造先调用,子类的构造在调用;然后执行相应的过程;最后释放父类指针时应该与构造过程相反,即先调用子类的析构函数,父类的析构在调用。)
总结:
1.虚析构或纯虚析构就是用来解决通过父类指针释放子类对象
2.如果子类中没有堆区数据,可以不写为虚析构或纯虚析构
3.拥有纯虚析构函数的类也属于抽象类