C++中如何使用虚析构函数

C++中如何使用虚析构函数,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

道里网站制作公司哪家好,找创新互联!从网页设计、网站建设、微信开发、APP开发、响应式网站设计等网站项目制作,到程序开发,运营维护。创新互联从2013年成立到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联

C++的多态性是通过虚函数来实现的,虚函数的出现使得动态链接成为可能。

基于构造函数的特点,不能将构造函数定义为虚函数,但可以将析构函数定义为虚函数。当派生类的对象从内存中撤销时,会先调用派生类的析构函数,然后自动调用基类的析构函数,如此看来析构函数也没有必要定义为虚函数。

但是考虑如下这种情况,如果使用基类指针指向派生类的对象,而这个派生类对象恰好是用new运算创建的,这种情况下会如何呢?当程序使用delete运算撤销派生类对象时,这时只会调用基类的析构函数,而没有调用派生类的析构函数。如果使用的是虚析构函数的话,就不一样了,所以定义虚析构函数有时候还是很有必要的。下面这段程序就说明了上面的问题:

没有定义虚C++虚析构函数时,code如下:

#include < iostream> using namespace std;  class A  {  public:  A(){}  ~A()  {  cout< < "A::destructor"< < endl;  }  };  class B:public A   {  public:  B(){}  ~B()  {  cout< < "B::destructor"< < endl;  }  };  int main()  {  A *pA = new B;  //  delete pA;  return 0;  }

输出的是A::destructor

这说明delete pA只是调用了基类A的析构函数,而没有调用子类B的析构函数,这不是我们所想要的。而把基类A的析构函数定义为虚函数后,就可以达到了我们所想要的效果了。code如下:

#include < iostream> using namespace std;  class A  {  public:  A(){}  virtual ~A()  {  cout< < "A::destructor"< < endl;  }  };  class B:public A   {  public:  B(){}  ~B()  {  cout< < "B::destructor"< < endl;  }  };  int main()  {  A *pA = new B;  //  delete pA;  return 0;  }

输出如下:

B::destrutor

A::destrutor

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。


文章名称:C++中如何使用虚析构函数
本文路径:http://myzitong.com/article/jcphjd.html