通过基类的指针在删除派生类对象时只调用了基类的析构函数,而没有调用派生类的析构函数,因此在有些程序中会存在问题。(例如需要在构造函数与析构函数中进行计数统计的程序)
实际效果:
删除一个派生类对象时
- 先调用派生类的析构函数
- 再调用基类的析构函数
解决办法:
把基类的析构函数声明为virtual
- 派生类的析构函数virtual不用声明
- 通过基类的指针删除派生类对象时
- 先调用派生类的析构函数
- 后调用基类的析构函数
类如果定义了虚函数,则最好将析构函数也定义成虚函数。不允许构造函数是虚函数。
代码如下:
#include <iostream> using namespace std; class Son { public: virtual ~Son() { cout << "the destructor of son is called" << endl; } }; class Grandson : public Son { public: ~Grandson() { cout << "the destructor of Grandson is called " << endl; } }; int main() { Son *p = NULL; p = new Grandson; delete p; return 0; }
程序运行结果为:
当析构函数不是virtual时,运行结果为:
纯虚函数和抽象类
没有函数体的虚函数叫纯虚函数。
包含纯虚函数的类叫抽象类。
- 只能作为基类来派生新类使用。
- 不能创建抽象类的对象。
- 抽象类的指针和引用指向派生类生出来的类的对象。
抽象类中:
- 在成员函数中可以调用纯虚函数
- 在构造函数和析构函数中不能调用纯虚函数
- 如果一个类从抽象类派生而来,只有当它实现了基类中所有的纯虚函数,才能成为非抽象类。
实验代码如下:
#include <iostream> using namespace std; class cSon { public: virtual void f() = 0; void g(void) { f(); } }; class cgrandson :public cSon { public: void f() { cout << "f() is called" << endl; } }; int main() { cgrandson b; cSon *p = &b; p->g(); return 0; }
运行结果:
参考链接:
https://www.coursera.org/learn/cpp-chengxu-sheji
本人博客已迁往 https://chenlongxiabc.github.io 欢迎访问。 博客内容均为自己编写,其中参考了相关内容。若有侵权他人请联系我,并对此表示歉意。若要转载或是其他用途,请联系我。我的邮箱diegefulan@hotmail.com
今天的文章虚析构函数_析构函数定义为虚函数的作用分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/51050.html