日期:2011-03-22 16:17:00 来源:本站整理
java内部类可以覆盖吗[Java编程]
本文“java内部类可以覆盖吗[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
若成立一个内部类,然后从封装类担当,并重新定义内部类,那么会呈现什么情形呢?也就是说,我们有大概覆盖一个内部类吗?这看起来仿佛是一个非常有效的概念,但“覆盖”一个内部类——好象它是外部类的另一个办法——这一概念实际不能做任何事情:
//: 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.Yolk明确地扩大了Egg2.Yolk,并且覆盖了它的办法.办法insertYolk()答应BigEgg2将它自己的某个Yolk对象上溯造型至Egg2的y句柄.所以当g()调用y.f()的时刻,就会利用f()被覆盖版本.输出后果以下://: 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(); } } ///:~
Egg2.Yolk()
New Egg2()
Egg2.Yolk()
BigEgg2.Yolk()
BigEgg2.Yolk.f()
对Egg2.Yolk()的第二个调用是BigEgg2.Yolk构建器的底子类构建器调用.调用
g()的时刻,可发现利用的是f()的被覆盖版本.
以上是“java内部类可以覆盖吗[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |
- ·上一篇文章:java内部类标识符
- ·下一篇文章:<b>从内部类承当</b>
- ·中查找“java内部类可以覆盖吗”更多相关内容
- ·中查找“java内部类可以覆盖吗”更多相关内容
评论内容只代表网友观点,与本站立场无关!
评论摘要(共 0 条,得分 0 分,平均 0 分)
查看完整评论