1.当自己的类指针指向自己类的对象时,无论调用的是虚函数还是实函数,其调用的都是自己的:
2.当指向父类对象的父类指针被强制转换成子类指针时候,子类指针调用函数时,只有非重写函数是自己的,虚函数是父类的;
3.当指向子类对象的子类指针被强制转换成父类指针的时候,也就是父类指针指向子类对象,此时,父类指针调用的虚函数都是子类的,而非虚函数都是自己的;
将上面三句话总结成一句话就是:当父类子类有同名非虚函数的时候,调用的是转换后的指针类型的函数;
当父类子类有同名虚函数的时候呢,调用的是指针转换前指向的对象类型的函数。
详见以下代码:
1 #include <iostream> 2 using namespace std; 3 class Base { 4 public: 5 virtual void f() { cout << "Base::f" << endl; } 6 virtual void g() { cout << "Base::g" << endl; } 7 void h() { cout << "Base::h" << endl; } 8 9 }; 10 class Derived:public Base 11 { 12 public: 13 virtual void f(){cout<<"Derived::f"<<endl;} 14 void g(){cout<<"Derived::g"<<endl;} 15 void h(){cout<<"Derived::h"<<endl;} 16 }; 17 18 19 void main() 20 { 21 Base *pB=new Base(); 22 cout<<"当基类指针指向基类对象时:"<<endl; 23 pB->f(); 24 pB->g(); 25 pB->h(); 26 cout<<endl; 27 28 Derived *pD=(Derived*)pB; 29 cout<<"当父类指针被强制转换成子类指针时:"<<endl; 30 pD->f(); 31 pD->g(); 32 pD->h(); 33 cout<<endl; 34 35 Derived *pd=new Derived(); 36 cout<<"当子类指针指向子类时候"<<endl; 37 pd->f(); 38 pd->g(); 39 pd->h(); 40 cout<<endl; 41 42 Base *pb=(Base *)pd; 43 cout<<"当子类指针被强制转换成父类指针时:"<<endl; 44 pb->f(); 45 pb->g(); 46 pb->h(); 47 cout<<endl; 48 49 Base *pp=new Derived(); 50 cout<<"父类指针指向子类对象时候:"<<endl; 51 pp->f(); 52 pp->g(); 53 pp->h(); 54 cout<<endl; 55 }
执行结果如下图: