网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.通过socket传递java对象(对象序列.
.使用Decorator模式 翻译者:Disn.
.容易忽视的Java三用法小议.
.Hibernate + Proxool配置.
.SCJP:“菜鸟”也能玩Java.
.JDK1.4下实现访问WIN32注册表.
.面向方面编程AOP和JBoss(一).
.JAVA的反编译.
.Java多线程中的两个问题.
.Java核心编程:卷I——学习小记.
.世界robocode机器人的四大运动方.
.在 Java 应用程序中计划重复执行.
.教程——漫谈Java程序设计中的接.
.Eclipse插件Continuous Tes.
.关于java vm的垃圾收集.
.Java开发为什么需要UML.
.一个Socket服务的例子! 请高手指.
.超越梦想 EJB 3.0规范全新体验.
.手把手教你使用Java来编写ASP组件.
.一个容易疏忽的多线程程序陷阱.

多形性的覆盖与过载

发表日期:2008-1-5



  现在让我们用不同的眼光来看看本章的头一个例子。在下面这个程序中,方法play()的接口会在被覆盖的过程中发生变化。这意味着我们实际并没有“覆盖”方法,而是使其“过载”。编译器答应我们对方法进行过载处理,使其不报告出错。但这种行为可能并不是我们所希望的。下面是这个例子:
  
  //: WindError.Java
  // Accidentally changing the interface
  
  class NoteX {
   public static final int
    MIDDLE_C = 0, C_SHARP = 1, C_FLAT = 2;
  }
  
  class InstrumentX {
   public void play(int NoteX) {
    System.out.println("InstrumentX.play()");
   }
  }
  
  class WindX extends InstrumentX {
   // OOPS! Changes the method interface:
   public void play(NoteX n) {
    System.out.println("WindX.play(NoteX n)");
   }
  }
  
  public class WindError {
   public static void tune(InstrumentX i) {
    // ...
    i.play(NoteX.MIDDLE_C);
   }
   public static void main(String[] args) {
    WindX flute = new WindX();
    tune(flute); // Not the desired behavior!
   }
  } ///:~
  
  这里还向大家引入了另一个易于混淆的概念。在InstrumentX中,play()方法采用了一个int(整数)数值,它的标识符是NoteX。也就是说,即使NoteX是一个类名,也可以把它作为一个标识符使用,编译器不会报告出错。但在WindX中,play()采用一个NoteX句柄,它有一个标识符n。即便我们使用“play(NoteX NoteX)”,编译器也不会报告错误。这样一来,看起来就象是程序员有意覆盖play()的功能,但对方法的类型定义却稍微有些不确切。然而,编译器此时假定的是程序员有意进行“过载”,而非“覆盖”。请仔细体会这两个术语的区别。“过载”是指同一样东西在不同的地方具有多种含义;而“覆盖”是指它随时随地都只有一种含义,只是原先的含义完全被后来的含义取代了。请注重假如遵守标准的Java命名规范,自变量标识符就应该是noteX,这样可把它与类名区分开。
  
  在tune中,“InstrumentX i”会发出play()消息,同时将某个NoteX成员作为自变量使用(MIDDLE_C)。由于NoteX包含了int定义,过载的play()方法的int版本会得到调用。同时由于它尚未被“覆盖”,所以会使用基础类版本。
  
  输出是:
  
  InstrumentX.play()
上一篇:下溯造型与运行期类型标识 人气:621
下一篇:为什么要用内部类:控制框架 人气:702
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐