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++ 继承--派生类.ppt

继承--派生类 继承的概念 软件复用:降低成本、提高软件可靠性 目前,不加修改地直接复用已有软件比较困难。已有软件的功能与新软件所需要的功能总是有差别的。解决这个差别有下面的途径: 修改已有软件的源代码,它的缺点是: 需读懂源代码 可靠性差、易出错 源代码难以获得 继承机制(Inheritance): 一种面向对象的软件复用途径 在定义一个新的类时,先把一个或多个已有类的功能全部包含进来,然后再给出新功能的定义或对已有类的某些功能重新定义。 C++的继承通过派生类来实现 基类与派生类 在继承关系中存在两个类:基类(或称父类)和派生类(或称子类)。派生类拥有基类的所有特征,并可以定义新的特征或对基类的一些特征进行重定义。 继承对程序设计的支持 继承机制除了支持软件复用外,它还具有下面的作用: 对事物进行分类:层次结构,is-a-kind-of 支持软件的增量开发:新的版本可以从老的版本扩展和完善 对概念进行组合:例如在职研究生既是教师,又是研究生,综合了两种特征 单继承 在定义单继承时,派生类只能有一个直接基类,其定义格式如下: class 派生类名:[继承方式] 基类名 { 成员说明表 }; 派生类名为派生类的名字。 基类名为直接基类的名字。 成员说明表是在派生类中新定义的成员,其中包括对基类成员的重定义。 继承方式指出派生类的实例(对象)用户以及派生类的派生类对该派生类的基类成员的访问控制 class A //基类 { int x,y; public: void f(); void g(); }; class B: public A //派生类 { int z; //新成员 public: void h(); //新成员 }; 关于派生类的一些说明 除了拥有新定义的成员外,派生类还拥有基类的除私有成员外的所有成员(基类的构造函数和赋值操作符重载函数除外)。例如: B b; b b.x: b.y: b.z: b.f(); //A类中的f b.g(); //A类中的g b.h(); //B类中的h 派生类可以定义新的成员,也可以对基类成员重新进行定义。如果在派生类中新定义的成员与基类的某个成员同名,则在派生类中对该成员的访问是指派生类中定义的成员。例如: class B: public A { int z; public: void f(); void h() { f(); //B类中的f g(); //A类中的g } }; ...... B b; b.f(); //B类中的f b.g(); //A类中的g b.h(); //B类中的h 派生类成员名的作用域嵌套在基类作用域中。如果派生类中定义了与基类同名的成员,则基类的成员名在派生类的作用域内不直接可见。访问基类同名成员时要用基类名受限。例如: class B: public A { int z; public: void f(); void h() { f(); //B类中的f A::f(); //A类中的f } }; B b; b.f(); //B类中的f。 b.A::f(); //A类中的f 即使派生类中定义了与基类同名但参数不同的成员函数,基类的同名函数在派生类的作用域中也是不直接可见的: class B: public A { int z; public: void f(int); void h() { f(1); //OK f(); //Error A::f(); //OK } }; ...... B b; b.f(1); //OK b.f(); //Error b.A::f(); //OK 定义派生类时一定要见到基类的定义。 class A; //声明 class B: public A //Error { int z; public: void h() { g(); } //Error,编译程序不知道基类中是否有函数g以及函数g的原型。 }; ...... B b; //Error,编译无法确定b所需内存空间的大小。 如果在派生类中没有显式说明,基类的友元不是派生类的友元;如果基类是另一个类的友元,而该类没有显式说明,则派生类也不是该类的友元。 派生类不能直接访问基类的私有成员。例如: class A { int x,y; public: void f(); void g() { ... x ... } }; class B: public A { int z; public: void h() { ... x ...

文档评论(0)

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

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

1亿VIP精品文档

相关文档