当一个类中一旦有虚函数的时候,这个类的内存空间就会维护一张虚函数表,这张虚函数表会浪费类所占用的内存空间,同时虚函数是运行时多态,一旦函数被调用的次数非常多,就会产生性能的瓶颈,一般在数据库中的物理算子的实现中,会有这种情况的发生,因为数据库所处理的数据条数有时候是很多的。
但是如果一个基类的析构函数如果不是虚函数,我们看会发生什么事情。
#include <iostream>
using namespace std;
class A{
public:
A(){};
virtual ~A(){};
void check(){
cout<<"check in A"<<endl;
};
};
class B:public A{
public:
B(){};
~B(){
cout<<"B will be destroyed"<<endl;
};
};
int main(){
A *a=new B();
a->check();
delete a;
return 0;
}
运行结果为:
check in A
B will be destroyed
但是如果你去掉virtual ~A()的virtual,出现的结果是:
check in A
这说明如果基类中的析构函数如果不是虚函数,子类中的析构函数就不会被执行,这样就可能导致内存泄露的风险,如果你在子类中的析构函数中做了更多的事情,就可能会有更严重的后果。