网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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,移动开发
本月文章推荐
.基于Java的Web服务器工作原理(2).
.java常见缩略词及英文对照.
.WebLogic Server 中CM.
.tomcat的sqlserver数据源的配置.
.Win2003中apache2整合tomcat5和i.
.让你学习控制住Web2.0的方向盘二.
.POJO应用架构:Spring与EJB 3.0的.
.moveFirst 方法.
.浅谈Java中利用JCOM实现仿Excel编.
.Java 纵 横 谈.
.实现高效Java编程规范的十一条基.
.在组合模式中实现访问者(Visitor.
.将DBMS存储过程封装为会话EJB组件.
.了解Hibernate的FlushMode.NEVER.
.回击Ruby, Groovy on&.
.java中文乱码解决方案和经验.
.新手学堂:漫谈EJB在Java中的应用.
.跟你分享——.Net项目制作安装程.
.Eclipse快速上手指南之使用CVS.
.通过ClassLoader管理组件依赖(图).

内部类可以覆盖吗?

发表日期:2008-1-5



  若创建一个内部类,然后从封装类继续,并重新定义内部类,那么会出现什么情况呢?也就是说,我们有可能覆盖一个内部类吗?这看起来似乎是一个非常有用的概念,但“覆盖”一个内部类——好象它是外部类的另一个方法——这一概念实际不能做任何事情:
  
  //: BigEgg.Java
  // An inner class cannot be overriden
  // like a method
  
  class Egg {
   protected class Yolk {
    public Yolk() {
     System.out.println("Egg.Yolk()");
    }
   }
   private Yolk y;
   public Egg() {
    System.out.println("New Egg()");
    y = new Yolk();
   }
  }
  
  public class BigEgg extends Egg {
   public class Yolk {
    public Yolk() {
     System.out.println("BigEgg.Yolk()");
    }
   }
   public static void main(String[] args) {
    new BigEgg();
   }
  } ///:~
  
  默认构建器是由编译器自动合成的,而且会调用基础类的默认构建器。大家或许会认为由于预备创建一个BigEgg,所以会使用Yolk的“被覆盖”版本。但实际情况并非如此。输出如下:
  
  New Egg()
  Egg.Yolk()
  
  这个例子简单地揭示出当我们从外部类继续的时候,没有任何额外的内部类继续下去。然而,仍然有可能“明确”地从内部类继续:
  
  //: BigEgg2.java
  // Proper inheritance of an inner class
  
  class Egg2 {
   protected class Yolk {
    public Yolk() {
     System.out.println("Egg2.Yolk()");
    }
    public void f() {
     System.out.println("Egg2.Yolk.f()");
    }
   }
   private Yolk y = new Yolk();
   public Egg2() {
    System.out.println("New Egg2()");
   }
   public void insertYolk(Yolk yy) { y = yy; }
   public void g() { y.f(); }
  }
  
  public class BigEgg2 extends Egg2 {
   public class Yolk extends Egg2.Yolk {
    public Yolk() {
     System.out.println("BigEgg2.Yolk()");
    }
    public void f() {
     System.out.println("BigEgg2.Yolk.f()");
    }
   }
   public BigEgg2() { insertYolk(new Yolk()); }
   public static void main(String[] args) {
    Egg2 e2 = new BigEgg2();
    e2.g();
   }
  } ///:~
  
  现在,BigEgg2.Yolk明确地扩展了Egg2.Yolk,而且覆盖了它的方法。方法insertYolk()答应BigEgg2将它自己的某个Yolk对象上溯造型至Egg2的y句柄。所以当g()调用y.f()的时候,就会使用f()被覆盖版本。输出结果如下:
  
  Egg2.Yolk()
  New Egg2()
  Egg2.Yolk()
  BigEgg2.Yolk()
  BigEgg2.Yolk.f()
  
  对Egg2.Yolk()的第二个调用是BigEgg2.Yolk构建器的基础类构建器调用。调用
  
  g()的时候,可发现使用的是f()的被覆盖版本。
上一篇:从内部类继承 人气:757
下一篇:引用外部类对象 人气:655
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐