前言
因为内部类的构造器必须连接到指向其外围类对象的引用,所以在继承内部类的时候,事情会变得有点复杂。问题在于,那个指向外围类对象的“秘密的”引用必须被初始化,而在导出类中不再存在可连接的默认对象。要解决这个问题,必须使用特殊的语法来明确说清它们之间的关系:
示例源码
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()
这样才提供了必要的引用,然后程序才能编译通过。
时间: 2024-08-07 15:00:43