c++ 多态、覆盖、重载的综述
2017-04-15 16:01
148 查看
1、多态:
在基类中定义了一个虚拟函数,然后在派生类中又定义一个同名,同参数表的函数,这就是多态。多态是这3种情况中唯一采用动态绑定技术的一种情况。也就是说,通过一个基类指针来操作对象,如果对象是基类对象,就会调用基类中的那个函数,如果对象实际是派生类对象,就会调用派声类中的那个函数,调用哪个函数并不由函数的参数表决定,而是由函数的实际类型决定。
一个操作随着所传递或捆绑的对象类型的不同能够做出不同的反应,其行为模式称为多态。
c++使用滞后捆绑技术支持多态,这种技术通过预先设定其成员函数的虚函数性质,使得任何捆绑该成员函数的未定类型的对象操作在编译时,都以一个不确定的指针特殊的“引命待发”来编码,到了运行时,遇到确定类型的对象,才突然指定其真正的行为。即滞后到运行时根据具体类型的对象来捆绑成员函数。这样一来,辨别对象类型的工作就可以不用用户做了。
如果一种语言虽然支持继承,但不支持多态,则不能称为支持面向对象编程。
//poly.cpp
输出为:
2、覆盖:
在基类中定义了一个非虚拟函数,然后在派生类中又定义了一个同名同参数同返回类型的函数,这就是覆盖了。
覆盖函数往往先调用祖先类中的被覆盖函数,之后再添加自身的特殊操作。
在派生类对象上直接调用这个函数名,只会调用派生类中的那个。
//coverage.cpp
输出为:
3、重载:
有两个或多个函数名相同的函数,但是函数的形参列表不同。在调用相同函数名的函数时,根据形参列表确定到底该调用哪一个函数。
//reload
输出为:
在基类中定义了一个虚拟函数,然后在派生类中又定义一个同名,同参数表的函数,这就是多态。多态是这3种情况中唯一采用动态绑定技术的一种情况。也就是说,通过一个基类指针来操作对象,如果对象是基类对象,就会调用基类中的那个函数,如果对象实际是派生类对象,就会调用派声类中的那个函数,调用哪个函数并不由函数的参数表决定,而是由函数的实际类型决定。
一个操作随着所传递或捆绑的对象类型的不同能够做出不同的反应,其行为模式称为多态。
c++使用滞后捆绑技术支持多态,这种技术通过预先设定其成员函数的虚函数性质,使得任何捆绑该成员函数的未定类型的对象操作在编译时,都以一个不确定的指针特殊的“引命待发”来编码,到了运行时,遇到确定类型的对象,才突然指定其真正的行为。即滞后到运行时根据具体类型的对象来捆绑成员函数。这样一来,辨别对象类型的工作就可以不用用户做了。
如果一种语言虽然支持继承,但不支持多态,则不能称为支持面向对象编程。
//poly.cpp
#include <iostream> using namespace std; class A { public: virtual void ShowMessage(); }; class B:public A { public: void ShowMessage(); }; void A::ShowMessage() { cout<<"This is A./n"; return; } void B::ShowMessage() { cout<<"This is B./n"; return; } int main() { A* p; p=new A(); p->ShowMessage(); p=new B(); p->ShowMessage(); return 0; }
输出为:
This is A. This is B.
2、覆盖:
在基类中定义了一个非虚拟函数,然后在派生类中又定义了一个同名同参数同返回类型的函数,这就是覆盖了。
覆盖函数往往先调用祖先类中的被覆盖函数,之后再添加自身的特殊操作。
在派生类对象上直接调用这个函数名,只会调用派生类中的那个。
//coverage.cpp
#include <iostream> using namespace std; class A { public: void ShowMessage(); }; class B:public A { public: void ShowMessage(); }; void A::ShowMessage() { cout<<"Hello,This is A./n"; return; } void B::ShowMessage() { cout<<"Hello,This is B./n"; return; } int main() { A* p; B memb; *p = memb; p->ShowMessage(); memb.ShowMessage(); return 0; }
输出为:
Hello,This is A. Hello,This is B.
3、重载:
有两个或多个函数名相同的函数,但是函数的形参列表不同。在调用相同函数名的函数时,根据形参列表确定到底该调用哪一个函数。
//reload
#include <iostream> using namespace std; class A { public: void ShowMessage(); void ShowMessage(string str); }; void A::ShowMessage() { cout<<"Hi,This is A./n"; return; } void A::ShowMessage(string str) { cout<<str<<endl; return; } int main() { A mem; mem.ShowMessage(); mem.ShowMessage("Hello.How are you?/n"); return 0; }
输出为:
Hi,This is A. Hello.How are you?
相关文章推荐
- [C++基础]重载、覆盖、多态与函数隐藏
- C++中的虚函数,多态,覆盖隐藏重载
- 2.1 C++ 多态 重载 覆盖
- C++中的重载,隐藏,覆盖,虚函数,多态浅析
- C++中的虚函数,多态,覆盖隐藏重载
- [C++基础]重载、覆盖、多态与函数隐藏(4)
- C++多态及重载(overload),覆盖(override),隐藏(hide)的区别
- 详解一道C++笔试题,考察重载、覆盖、多态
- [C++基础]重载、覆盖、多态与函数隐藏(2)
- 详解一道C++笔试题,考察重载、覆盖、多态
- c++覆盖,重载,多态
- c++中多态函数以及函数重载,覆盖,遮蔽(隐藏)的区别
- C++覆盖、重载、多态区别
- [C++基础]重载、覆盖、多态与函数隐藏(4)
- [C++基础]重载、覆盖、多态与函数隐藏(1)
- c++(一) 类 对象 重载 继承 多态 构造函数 虚函数 覆盖 纯虚函数等
- C++中的虚函数,多态,覆盖隐藏重载
- C++多态、重载和覆盖的区别
- c++中的重载、覆盖、多态的理解
- 转---C++学习之多态及重载(overload),覆盖(override),隐藏(hide)的区别