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文档。上传文档
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 继承时的析构函数   析构函数也不被继承,派生类自行定义。   定义方法与一般(无继承关系时)类的析构函数相同。   不需要显式地调用基类的析构函数,系统会自动隐式调用。   析构函数的调用次序与构造函数相反。 例7-5 派生类构造和析构函数举例 (多继承且含有内嵌对象) #include iostream.h class B1 //基类B1定义 { public: B1(int i){ cout constructing B1 i endl; } //B1的构造函数 ~B1() { cout destructing B1 endl; } //B1的析构函数 }; class B2 //基类B2定义 { public: B2(int j){ cout constructing B2 j endl; } //B2的构造函数 ~B2() { cout destructing B2 endl; } //B2的析构函数 }; class B3 //基类B3定义 { public: B3(){cout constructing B3 * endl; } //B3的构造函数 ~B3() { cout destructing B3 endl; } //B3的析构函数 }; class C: public B2, public B1, public B3 //派生类C定义 { public: C(int a, int b, int c, int d):B1(a),memberB2(d),memberB1(c),B2(b){ } private: B1 memberB1; B2 memberB2; B3 memberB3; }; void main( ) { C obj(1,2,3,4); } /********** 程序运行结果 ********** constructing B2 2 constructing B1 1 constructing B3 * constructing B1 3 constructing B2 4 constructing B3 * destructing B3 destructing B2 destructing B1 destructing B3 destructing B1 destructing B2 ************ 程序结束 ************/ 派生类与基类的关系 赋值兼容原则   一个派生类的对象在使用上可以被当作基类的对象,反之则禁止。 具体表现:   派生类的对象可以被赋值给基类对象。   派生类的对象可以初始化基类的引用。 指向派生类及基类对象的指针   以public方式继承时,指向基类的指针也可以指向派生类。 二义性问题 在多继承时,基类与派生类之间,或基类之间出现同名成员时,将出现访问时的二义性(不确定性)——采用虚函数(第8章)或支配(同名覆盖)原则来解决。   当派生类从多个基类派生,而这些基类又从同一个基类派生,则在访问此共同基类中的成员时,将产生二义性——采用虚基类来解决。 二义性问题举例 class B { public: int b; } class B1 : public B { private: int b1; } class B2 : public B { private: int b2; }; class C : public B1,public B2 { public: int f(); private: int d; } 下面的访问是二义性的: C c; c.b c.B::b 下面是正确的: c.B1::b c.B2::b 二义性的解决方法 解决方法一:   用类名来限定:  c1.A::f() 或 c1.B::f() 解决方法二:   同名覆盖:在C 中定义一个同名成员函数f(),f()再根据需要调用 A::f() 或 B::f() 同名覆盖原则 当派生类与基类中有相同成员时:   若未强行指名,则通过派生类对象使用的是派生类中的同名成员。   如要通过派

文档评论(0)

kehan123 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档