C++课件汇总虚函数.pptVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * * * * * * * * 回顾:类型兼容 一个公有派生类的对象在使用上可以被当作基类的对象,反之则禁止。具体表现在: 派生类的对象可以被赋值给基类对象。 派生类的对象可以初始化基类的引用。 指向基类的指针也可以指向派生类。 通过基类对象名、指针只能使用从基类继承的成员 类型兼容 * 静态联编与动态联编 绑定 程序自身彼此关联的过程,确定程序中的操作调用与执行该操作的代码间的关系。 静态联编 联编工作出现在编译阶段,用对象名或者类名来限定要调用的函数。 动态联编 联编工作在程序运行时执行,在程序运行时才确定将要调用的函数。 C++语言程序设计教程 第9章 多态性 9.3 虚函数 9.3.1 静态联编与动态联编 调用重载函数时,编译器根据调用时参数的类型与个数在编译时实现静态联编,将调用体与函数绑定。静态联编支持的多态性也称为编译时的多态性,或静态多态性。 【例9-6】演示静态多态性 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 /******************************************** * p9_6.cpp * * 演示静态多态性 * ********************************************/ #includeiostream using namespace std; class Point { private: int X,Y; public: Point(int X=0,int Y=0) { this-X=X,this-Y=Y; } double area() //求面积 { return 0.0; } }; const double PI=3.14159; C++语言程序设计教程 第9章 多态性 9.3.1 静态联编与动态联编 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 class Circle :public Point { private: double radius; //半径 public: Circle(int X, int Y, double R):Point(X,Y) { radius=R; } double area() //求面积 { return PI*radius*radius; } }; int main() { Point P1(10,10); coutP1.area()=P1.area()endl; Circle C1(10,10,20); coutC1.area()=C1.area()endl; Point *Pp; Pp=C1; coutPp-area()=Pp-area()endl; Point Rp=C1; coutRp.area()=Rp.area()endl; return 0; } 运行结果: P1.area()=0 C1.area()=1256.64 Pp-area()=0 Rp.area()=0 C++语言程序设计教程 第9章 多态性 9.3.1 静态联编与动态联编 程序解释: 程序39行调用P1.area()显示了Point类对象P1的面积; 程序41行通过调用C1.area() 显示了Circle类对象C1的面积;由于在类Circle中重新定义了area(), 它覆盖了基类的 area(), 故通过C1.area()调用的是类Circle中的area(), 返回了正确结果。 依照类的兼容性,程序43行用一个point型的指针指向了Circle类的对象C1, 第44行通 过Pp-area()调用area(), 那么究竟调用的是哪个area(), C++此时实行静态联编,根据 Pp的类型为Point型,将从Point类中继承来的area()绑定给Pp, 因此,此时调用的是 Point派生的area(), 显示的结果为0。 同样,在第46行由引用Rp调用area()时,也进行静态联编,调用的是Point派生的 area(), 显示的结果为0。 显然,静态联编盲目根据指针和引用的类型而不是根据实际指向的目

文档评论(0)

开心农场 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档