C++菜鸟常见错误整理(第十一天)

C++的虚函数
 
       简单地说,那些被virtual关键字修饰的 成员函数 ,就是虚函数。虚函数的作用,就是实现 多态性 ,多态性是将
接口与实现进行分离;用形象的语言来解释就是实现以共同的方法,但因个体差异而采用不同的策略。
class A{
public:
void print(){ cout<<"This is A"<<endl;}
};
class B:public A{
public:
void print(){ cout<<"This is B"<<endl;}
};
int main(){ //为了在以后便于区分,我这段main()代码叫做main1
A a;
B b;
a.print();
b.print();  }
 
    通过class A和class B的print()这个接口,可以看出这两个class因个体的差异而采用了不同的策略,输出的结果分别是This is A和This is B。但这是否真正做到了 多态性 呢?No,多态还有个关键之处就是一切用指向 基类 指针 或引用来操作对象。那现在就把main()处的代码改一改。
int main(){ //main2
A a;
B b;
A* p1=&a;
A* p2=&b;
p1->print();
p2->print();
}
      运行一下,结果却是两个This is A。问题来了,p2明明指向的是class B的对象但却是调用的class A的print()函数,这不是我们所期望的结果,那么解决这个问题就需要用到虚函数
class A{
public:
virtual void print(){ cout<<"This is A"<<endl;} //现在成了虚函数了
};
class B:public A{
public:
void print(){ cout<<"This is B"<<endl;} //这里也就成了虚函数
};
       毫无疑问,class A的 成员函数 print()已经成了虚函数,那么class B的print()也成虚函数了,我们只需在把基 类的成员函数 设为virtual,其 派生类 的相应的函数也会自动变为虚函数。
 
       现在重新运行main2的代码,这样输出的结果就是This is A和This is B
       指向 基类 指针 在操作它的 多态 类对象时,会根据不同的类对象,调用其相应的函数,这个函数就是虚函数。

你可能感兴趣的:(虚函数)