关于“No enclosing instance of type * is accessible. Must qualify the allocation with an enclo……”的总结与思考

本文总结了在Java中遇到'No enclosing instance of type * is accessible...'错误的原因和解决方案。当尝试在没有外部类实例的情况下创建内部类对象时,会触发此错误。错误信息表明需要使用外部类的实例来初始化内部类。通过理解内部类的实例化机制,即内部类需要外部类的引用,可以修正代码,例如:`x.new A()`,其中`x`是`OutterClass`的一个实例。此外,文章还探讨了使用静态嵌套类(nested class)作为替代策略,以避免此类错误,因为静态嵌套类不需要外部类实例即可创建,但只能访问外部类的静态成员。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

报错的完整信息:

No enclosing instance of type OutterClass is accessible. Must qualify the allocation with an enclosing instance of type OutterClass (e.g. x.new A() where x is an instance of OutterClass).

错误的出现背景:

Java

在类中添加内部类,并在main函数中通过语句:

OutterClass.InnerClass innerClass = new OutterClass.InnerClass();

试图构造内部类对象时出现。

完整结构如下:

public class OutterClass {

	class InnerClass {
		
		void print() {
			System.out.println("this is innerClass");
		}
		
	}
	
	public static void main(String[] args) {
		OutterClass.InnerClass innerClass = new OutterClass.InnerClass();
		innerClass.print();
	}
	
}

思考:

首先对报错信息进行理解,粗略翻译如下:“没有外部类的实例可以访问,必须用外部类型的实例限定内存分配(例如:x.new A()x是一个外部类类型的实例”。

根据如上信息不难找到修改方法,我们需要一个OutterClass实例outterClass,有了这个实例才能实现对InnerClass的实例化,修改代码如下:

public static void main(String[] args) {
		OutterClass outterClass = new OutterClass();
		OutterClass.InnerClass innerClass = outterClass.new InnerClass();
		innerClass.print();
	}

参考各方面资料,对此进行解释:

众所周知,内部类是可以访问到外部类中的所有元素的,这一实现是通过在创建内部类实例时秘密捕获一个外部类实例的引用完成的。也就是说,一个内部类在实例化时必定需要依赖一个外部类的实例,所以内部类不可单独实例化存在。

拓展:

除此之外,还可以通过使用嵌套类避免该错误。

嵌套类就是声明为static的内部类,与需要在创建时隐秘保存一个创建它的外部类实例的引用的内部类不同,创建嵌套类不需要外部类的实例,但声明为static也意味着嵌套类只能访问外部类的static元素。

至于如何设计,使用内部类还是嵌套类就需要根据实际情况考虑了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值