Java基础知识学习.docVIP

  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文档。上传文档
查看更多
Java基础知识学习

Java语言中接口优于抽象类 Java语言设计提供了两种机制,可以用来定义允许多个实现的类型:接口和抽象类。 因为Java只允许单继承,所以抽象类作为类型定义受到了极大的限制。现有的类可以很容易被更新,以实现新的接口。一般来说,无法更新现有的类来 扩展新的抽象类。如果你希望两个类来扩展一个抽象类,就必须把抽象类放到类型层次的高处,以便这两个类的一个祖先成为他的子类。这样会间接的 伤害到类的层次,迫使这个公共祖先的所有后代类都扩展这个新的抽象类,无论他对于这个后代类是否合适。 接口是定义mixin(混合类型)的理想选择。类除了实现他的“基本类型(primary type)”之外,还可以实现这个mixin类型,以表示提供了某些可供 选择的行为。 接口允许我们构造非层次结构的类型框架。包装类(wrapper class)模式,接口使得安全地增强类的功能成为可能。 通过对你导出的每个重要接口都提供一个抽象的骨架实现(skeletal implementation)类,把这个抽象类的优点结合起来。 必须认真研究接口,并确定哪些方法是最为基本的(primitive),其他的方法则可以根据他们来实现。这些基本的方法将成为骨架实现类中抽象方法 。然后,必须为接口中所有其他的方法提供具体的实现。 抽象类的演变比接口的演变要容易的多。接口一旦被公开发行,并且已被广泛实现,再想改变这个接口几乎是不可能的。 java的动态绑定 所谓的动态绑定就是指程执行期间(而不是在编译期间)判断所引用对象的实际类型,根据其实际的类型调用其相应的方法。 java继承体系中的覆盖就是动态绑定的,看一下如下的代码: class Father { public void method(){ System.out.println(This is Fathers method); } } class Son1 extends Father{ public void method(){ System.out.println(This is Son1s method); } } class Son2 extends Father{ public void method(){ System.out.println(This is Son2s method); } } public class Test { public static void main(String[] args){ Father s1 = new Son1(); s1.method(); Father s2 = new Son2(); s2.method(); } } 运行结果如下: This is Son1s method This is Son2s method 通过运行结果可以看到,尽管我们引用的类型是Father类型的,但是运行时却是调用的它实际类型(也就是Son1和Son2)的方法,这就是动态 绑定。在java语言中,继承中的覆盖就是是动态绑定的,当我们用父类引用实例化子类时,会根据引用的实际类型调用相应的方法。 java的静态绑定 相对于动态绑定,静态绑定就是指在编译期就已经确定执行哪一个方法。在java中,方法的重载(方法名相同而参数不同)就是静态绑定的,重 载时,执行哪一个方法在编译期就已经确定下来了。看一下代码: class Father {} class Son1 extends Father{} class Son2 extends Father{} class Execute { public void method(Father father){ System.out.println(This is Fathers method); } public void method(Son1 son){ System.out.println(This is Son1s method); } public void method(Son2 son){ System.out.println(This is Son2s method); } } public class Test { public static void main(String[] args){ Father father = new Father(); Father s1 = new Son1(); Father s2 = new Son2(); Execute exe = new Execute(); exe.method(father); exe.method(s1); exe.met

文档评论(0)

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

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

1亿VIP精品文档

相关文档