Java 接口的实例化没有任何实际意义

本文探讨了Java中接口不能实例化的原理,指出接口实例化没有实际意义,因为接口仅包含静态属性和方法声明,这些存在于代码区和静态数据区。同时,通过匿名内部类的例子说明了如何实现接口的功能。文章还提到了内存的栈和堆模型,解释了对象在内存中的存储方式。

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

一、接口的实例化没有任何实际意义

实例化的意义是在JVM的堆中开辟出一块内存空间。其实用底层代码在内存中开辟出一块空间很容易,Java 之所以设定不允许接口实例化,那就是接口的实例化没有任何实际意义,只会占用一块内存空间,却不会在这块空间中放任何实际的值。所以 Java 主动规避掉了这个问题。

二、理解


Person per = new Person();此处声明 Person 对象 per,并且实例化一个 Person 对象,实际是在堆中开辟出一块空间来存放 Person 对象,per 则是指向这块空间,也就是内存中的一块地址。这块地址中所存放的值就是该 Person 对象的一些属性。

由图,栈中存放的是 per,值是堆中具体 Person 对象的地址,也就是 per 指向该具体类的引用。而堆中一块地址,存放的值是 Person 类的成员变量(局部变量在执行时存放在栈中)。

那么接口呢?假设可以 new 出一个接口,那么该接口就会占用堆中的一块地址,想想接口的这块地址上能够存放什么值呢?

说到这个首先要清楚接口中允许有什么:静态的属性以及方法声明。Java 的内存空间分为四类:栈(stack)、堆(heap)、代码(code)、静态数据(data)。由此可见接口中所有的东西的具体值都是存放在代码区和静态数据区的,所以接口的这块地址上并没有任何实际的值需要存储,那就没有必要给它一块地址来浪费空间。

三、匿名内部类

Thread t = new Thread(new Runnable(){
    @Override
    public void run(){
       ...
    }
})

接口不能实例化,Runnable 是一个接口,此处不是用 new 来实例化了吗?这是个假象的实例化,这种叫做匿名内部类,其只是省略掉了类的名字,实质等同于如下代码:

class MyThread implements Runnable{
    @Override
    public viod run(){
        ...
    }
}
//另一个类的main方法中
Thread t = new Thread(new MyThread());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JFS_Study

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值