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