在学习编程的过程中,我觉得不止要获得课本的知识,更多的是通过学习技术知识提高解决问题的能力,这样我们才能走在最前方,更多Java学习,请搜索疯狂Java;
在创建非静态内部类时,经常会遇到“No enclosing instance of type * isaccessible. Must qualify the allocation with an enclosing instance of type*(e.g. x.new A() where x is an instance of *).”这样的报错,其实原因只有一点,内部类是依赖于外部类存在的,所以在使用非静态内部类时,要求先实例化外部类才可以使用内部类。关于非静态内部类,我们可以把它理解成外部类的成员变量,我们在使用一个类的非静态成员变量时要求先对类进行实例化,然后通过对象来调用这个类的非静态成员变量。这里非静态内部类同外部类的关系,就如同非静态成员变量同类的关系一样。所以在使用非静态内部类时,要求先实例化外部类。
下面我给出例子来分析一下:
package com.csc.innerclasstest;
/**
*
* @author csc
*
*/
//外部类
public class OuterClass {
/**
* @param args
*/
public static void main(String[] args) {
InnerClass innerClass = new InnerClass();
innerClass.say();
System.out.println("I am in OuterClass!");
}
//定义一个内部类
private class InnerClass{
private void say() {
System.out.println("I am inInnerClass!");
}
}
}
上面的代码的第16行将会报出“Noenclosing instance of type OuterClass is
accessible. Must qualify the allocationwith an enclosing instance of type OuterClass
(e.g. x.new A() where x is an instance ofOuterClass).”这样的编译错误。错误的原因如上面红色字体所述。
解决方法一:将非静态内部类转换成静态内部类,即在上面程序的第21行的“Private”后面加上“Static”即可。
解决方法二:先实例化外部类,然后通过外部类来调用内部类的构造函数,代码如下:
package com.csc.innerclasstest;
/**
*
* @author csc
*
*/
//外部类
public class OuterClass {
/**
* @param args
*/
public static void main(String[] args) {
//实例化外部类
OuterClass outerClass = new OuterClass();
//通过外部类引用内部类
InnerClass innerClass = outerClass.newInnerClass();
innerClass.say();
System.out.println("I am inOuterClass!");
}
//定义一个内部类
private class InnerClass{
private void say() {
System.out.println("I am inInnerClass!");
}
}
}
上面代码的16行先进行了外部类的实例化,第18行通过外部类来引用内部类,这样就不会出现“No enclosing instance of type OuterClass isaccessible. Must qualify the allocation with an enclosing instance of typeOuterClass (e.g. x.new A() where x is an instance of OuterClass”这个编译报错了。
疯狂Java培训fkjava的课程采用针对性培养,全面提升学员就业能力,重点加强训练职业素质。老师辛勤的讲解,让学员充分感受Java的魅力,充分激发每个学员对于编程的热爱,让学员在半年的时间内掌握8-10万的代码量,成为真正的技术高手,疯狂Java采用企业全真模拟开发训练,迅速积累项目经验。让学员迅速获得其他人需要花费两年才能获得的工作技能,无忧就业!