Java-面向对象(高级篇)--继承的进一步研究.docxVIP

Java-面向对象(高级篇)--继承的进一步研究.docx

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
了解了继承的基本概念后,下面对继承操作中的一些注意点进行研究。 子类对象的实例化过程 在继承的操作中,对于子类对象实例化也是有要求的,及子类对象在实例化之前必须首先调用父类中的构造方法后在调用自己的构造方法。 【子类的实例化过程】 class Person { private String name; private int age; public Person(){ System.out.println(这是父类中的构造方法); } public String getName(){ return name; } public void setName(String name){ this.name=name; } public int getAge(){ return age; } public void setAge(int age){ this.age=age; } } class Student extends Person { private String school; public Student(){ System.out.println(这是子类中的构造方法); } public void setSchool(String school){ this.school=school; } public String getSchool(){ return school; } } public class ExtDemo2 { public static void main(String args[]){ Student stu=new Student(); stu.setName(张三); stu.setAge(19); stu.setSchool(ZZU); System.out.println(姓名:+stu.getName()+,年龄:+stu.getAge()+,学校:+stu.getSchool()); } } 运行结果为: 从运行结果可以清楚的发现,子类对象在实例化前会默认调用父类中的构造方法。就好像没有父类就没有孩子。 当然对于以上代码实际上在子类的构造方法中隐含了一个super()的语法,代码如下: class Student extends Person { private String school; public Student(){ super(); System.out.println(这是子类中的构造方法); } public void setSchool(String school){ this.school=school; } public String getSchool(){ return school; } } 以上程序的运行结果与之前是一样的。super表示超级的意思,在一些书中也喜欢把父类叫做超类,上面的语法就是表示子类可以直接使用super()调用父类(超类)中的无参构造。 方法的覆写 在继承的关系中也存在着方法覆写的概念,所谓的方法覆写就是子类定义了与父类中名称相同的方法,但是在覆写时必须考虑到权限,即被子类覆写的方法不能拥有比父类方法更严格的访问权限。 【方法的覆写】 class Person { void print(){ System.out.println(Person--void print(){}); } } class Student extends Person { public void print(){ System.out.println(Student--void print(){}); } } public class OverrideDemo01 { public static void main(String args[]){ new Student().print(); } } 运行结果为: 从程序的运行结果可以发现,Student子类定义了与Person父类中同名的方法,但是在子类中此方法的访问权限被扩大了,符合覆写的概念,当方法被覆写后,子类对象调用的就是被覆写后的方法。 需要注意的是,在被子类覆写的方法权限缩小时,会在编译时产生错误。 实际上与方法的覆写概念相同的还有另外一种称为属性的覆盖,这点在开发中使用较少。 【属性的覆盖】 class Person { public String info=ZZU; } class Student extends Person { public String info=zhao; public void print(){ System

您可能关注的文档

文档评论(0)

151****9996 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档