我正在使用 gcc。当我们销毁由基类指针指向的派生类对象时,我知道虚拟析构函数如何解决问题。我想知道它们是如何工作的?
class A
{
public:
A(){cout<<"A constructor"<<endl;}
~A(){cout<<"A destructor"<<endl;}
};
class B:public A
{
public:
B(){cout<<"B constructor"<<endl;}
~B(){cout<<"B destructor"<<endl;}
};
int main()
{
A * a = new B();
delete a;
getch();
return 0;
}
当我把A的析构函数改成虚函数时,问题就解决了。为此的内在工作是什么。为什么我要使 A 的析构函数成为虚拟的。我想知道 A 和 B 的 vtable 发生了什么?
最佳答案
虚析构函数只是一个虚函数,所以它遵守相同的规则。
当您调用delete a
时,会隐式调用析构函数。如果析构函数不是虚拟的,您将被称为 a->~A()
,因为它像其他所有非虚拟函数一样被调用。
但是,如果析构函数是虚拟的,您将按预期调用 ~B()
:析构函数是虚拟的,因此被调用的是派生类的析构函数,而不是基类。
编辑:
请注意,基 类的析构函数将在派生类的析构函数完成后隐式调用。这与通常的虚函数不同。
关于c++ - 虚拟析构函数如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2690473/