在创建非静态内部类时经常会遇到No enclosing instance of type * is accessible Must qualify the allocation with an enclosing instance of type *(eg xnew A() where x is an instance of *)这样的报错其实原因只有一点内部类是依赖于外部类存在的所以在使用非静态内部类时要求先实例化外部类才可以使用内部类关于非静态内部类我们可以把它理解成外部类的成员变量我们在使用一个类的非静态成员变量时要求先对类进行实例化然后通过对象来调用这个类的非静态成员变量这里非静态内部类同外部类的关系就如同非静态成员变量同类的关系一样所以在使用非静态内部类时要求先实例化外部类
下面我给出例子来分析一下
package comcscinnerclasstest;
/**
*
* @author csc
*
*/
//外部类
public class OuterClass {
/**
* @param args
*/
public static void main(String[] args) {
InnerClass innerClass = new InnerClass();
innerClasssay();
Systemoutprintln(I am in OuterClass!);
}
//定义一个内部类
private class InnerClass{
private void say() {
Systemoutprintln(I am in InnerClass!);
}
}
}
上面的代码的第行将会报出No enclosing instance of type OuterClass is accessible Must qualify the allocation with an enclosing instance of type OuterClass (eg xnew A() where x is an instance of OuterClass)这样的编译错误错误的原因如上面红色字体所述
解决方法一将非静态内部类转换成静态内部类即在上面程序的第行的Private后面加上Static即可
解决方法二先实例化外部类然后通过外部类来调用内部类的构造函数代码如下
package comcscinnerclasstest;
/**
*
* @author csc
*
*/
//外部类
public class OuterClass {
/**
* @param args
*/
public static void main(String[] args) {
//实例化外部类
OuterClass outerClass = new OuterClass();
//通过外部类引用内部类
InnerClass innerClass = outerClassnew InnerClass();
innerClasssay();
Systemoutprintln(I am in OuterClass!);
}
//定义一个内部类
private class InnerClass{
private void say() {
Systemoutprintln(I am in InnerClass!);
}
}
}
上面代码的行先进行了外部类的实例化第行通过外部类来引用内部类这样就不会出现No enclosing instance of type OuterClass is accessible Must qualify the allocation with an enclosing instance of type OuterClass (eg xnew A() where x is an instance of OuterClass这个编译报错了