C++中的虚析构函数,C++陷阱

#include <iostream>
//虚析构函数是在派生类转换成为基类时出现。
//派生类默认可以转换成为基类
using namespace std;
class A
{
  public:
   virtual~A(){
   cout<<"~A()"<<endl;}
};
class B:public A
{
  public:
   ~B(){
   cout<<"~B()"<<endl;}
};
int main()
{
   B cb;
   A *pa=&cb;
   cout<<"***********"<<endl;
   delete pa;
   cout<<"***********"<<endl;
    return 0;
}


运行上述程序,然后把A类的virtual去掉试试。

发现星号那边少了一行是吧。基类指针指向派生了,则在最终析构中,会出现问题,如没有删除派生类中的多余物质。

virtual 函数运行时是通过一个虚函数表进行的,而普通还是则不是。

所有当析构函数为非virtual是,只执行了基类中析构函数,而是virtual时则顺着表来。

此时,若已被认定为虚析构函数,则以前基类析构函数的位置会被派生类析构函数代替。

也就是说,析构时,会自动运行派生类析构函数,而派生类的析构函数运行时,会自动运行基类析构函数。

 

 

成员 f()const函数默认带有*this,可是静态函数却没有,那么static f()const;这个定义是错的

你可能感兴趣的:(C++中的虚析构函数,C++陷阱)