前一个问题是:非多态情况下,用基类指针去访问派生类的函数。
那么又要问了:多态情况下,怎么用基类指针去访问基类的函数呢?当然这里指的是虚函数。
答案是:用取内容运算符*获得派生类对象,然后再强制转换成基类的对象,用它去调用即可。
ps. 同样的,在多态情况下,用基类指针new一个派生类对象,基类和派生类都会初始化一个对象,然后各自维护。
在用指针去调用数据成员、非虚成员函数时,两者完全相同。
唯一区别是,在多态时,基类指针调用虚函数时会转向派生类,而非多态时没有虚函数,因而没有这种特例。
下面是测试程序,随意感受一下~
![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)
![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
1 #include <iostream> 2 using namespace std; 3 4 class A 5 { 6 public: 7 8 virtual void f() 9 { 10 cout<<"A"<<endl; 11 } 12 13 }; 14 class B : public A 15 { 16 public: 17 18 void f() 19 { 20 cout<<"B"<<endl; 21 } 22 23 }; 24 25 26 void main() 27 { 28 A* p=new B; 29 p->f(); 30 (*p).f(); 31 static_cast<A>(*p).f(); 32 delete p; 33 }
输出是
这是做大摩的笔试题引出来的问题,还有好多关于C++语言细节的东西。做了才知道离精通C++还有很长路要走。
师傅!九九八十一难到啥时候是个头啊?