C++中,如果一个类有虚拟函数的时候,当使用该类的指针调用其虚函数的时候,代码会被编译器转换为使用虚函数表中保存的函数地址找到函数后二次调用,即:
class A
{
public:
virtual void Out(){this->Inner();};
virtual void Inner(){};
}
int main()
{
A* pA = new A();
pA->Out();
}
代码中A类的Out里的this->Inner();编译后形成的伪代码可能是这样的
void Out(const A* this)
{
this->(*vptr[2])();
}
但是,对于Out函数来说,不管在基类还是在派生类里面,既然进到这个函数里面的,this指针的类型已经明确了,就是自己本类了,因此,在Out函数里使用虚拟机制调用Inner函数其实是不必要的,因此,对于程序员来说,有必要在这里压制一下虚拟机制,具体的方法是:
virtual void Out(){A::Inner();};
这样就会显示调用A类的Inner函数,压制虚拟机制通过虚函数表调用Inner函数,节省不少开销。