前言
因为内部类的构造器必须连接到指向其外围类对象的引用,所以在继承内部类的时候,事情会变得有点复杂。问题在于,那个指向外围类对象的“秘密的”引用必须被初始化,而在导出类中不再存在可连接的默认对象。要解决这个问题,必须使用特殊的语法来明确说清它们之间的关系:
示例源码
package com.mufeng.thetenthchapter;
class WithInner {
public WithInner() {
// TODO Auto-generated constructor stub
System.out.println("WithInner constructor");
}
@Override
public String toString() {
// TODO Auto-generated method stub
return "WithInner";
}
class Inner {
public Inner() {
// TODO Auto-generated constructor stub
System.out.println("Inner constructor");
}
@Override
public String toString() {
// TODO Auto-generated method stub
return "Inner";
}
}
}
public class InheritInner extends WithInner.Inner {
public InheritInner(WithInner wi) {
// TODO Auto-generated constructor stub
wi.super();
System.out.println("InheritInner constructor");
}
@Override
public String toString() {
// TODO Auto-generated method stub
return "InheritInner";
}
public static void main(String[] args) {
WithInner wi = new WithInner();
InheritInner ii = new InheritInner(wi);
System.out.println(ii);
}
}
结果输出
WithInner constructor
Inner constructor
InheritInner constructor
InheritInner
源码解析
可以看到,
InheritInner只继承自内部类,而不是外围类。但是当要生成一个构造器时,默认的构造器并不算好,而且不能只是传递一个指向外围类对象的引用。此外,必须在构造器内部使用如下语法:
enclosingClassReference.super()
这样才提供了必要的引用,然后程序才能编译通过。