一句话搞懂Java中this和super的实现原理

写在前面

本文隶属于专栏《100个问题搞定Java虚拟机》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢!

本专栏目录结构和文献引用请见100个问题搞定Java虚拟机

解答

在 Java 中,每当一个对象创建后,Java 虚拟机都会给这个对象分配一个指向自身的引用,也就是 this。同时如果对象是子类对象,则还会有一个 super 引用指向当前对象的父类对象。

this 的本质是:编译器在调用某个实例方法时,实际上会把当前的实例对象的引用作为第一个参数传递给方法。
super 的本质是: invokespecial 指令。

补充

this 的作用

  1. 在类的方法定义中使用 this 关键字,表示使用该方法的对象的引用。
  2. 在一个类中,this 可以表示该类的当前实例。
  3. this 是对当前类对象的引用,对象只有被实例化才存在。

this 的实现原理

在任何实例方法里面,都可以通过“this”关键字访问到此方法所属的对象。

这个访问机制对Java程序的编写很重要, 而它的实现却非常简单,仅仅是通过 Javac 编译器 编译的时候把对this关键字的访问转变为对一个普通方法参数的访问, 然后在虚拟机调用实例方法时自动传入此参数而已。

因此在实例方法的局部变量表中至少会存在一个指向当前对象实例的局部变量,局部变量表中也会预留出第一个Slot位来存放对象实例的引用,方法参数值从1开始计算。

这个处理只对实例方法有效。

super的作用

  1. 如果子类在继承父类的非私有的方法和成员变量时,没有同名的方法和变量,可以直接通过名称使用父类的方法和变量。
  2. 如果子类存在与父类同名的方法和成员变量时,要想区别访问父类和自身的变量和方法,需要使用 super 关键字调用父类的方法和属性。

super 的实现原理

super 就是靠 invokespecial 指令来调用父类方法的。

invokespecial 指令的主要作用是,用于调用一些需要特殊处理的实例方法,包括实例初始化方法、私有方法和父类方法。

详情请见我的另一篇博客——Java虚拟机是如何识别目标方法的?

  • 13
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 24
    评论
Java桥接模式是一种结构型设计模式,它可以将抽象和实现分离开来,从而使它们可以独立地变化。桥接模式通过将继承关系转化为组合关系来实现这一点。在桥接模式,抽象和实现是通过一个桥接接口连接在一起的。这个桥接接口充当了抽象和实现之间的桥梁,使它们可以相互通信。 Java桥接模式的工作原理如下: 1. 定义一个桥接接口,该接口定义了抽象和实现之间的通信协议。 2. 创建一个抽象类,该类包含一个指向桥接接口的引用。 3. 创建一个实现类,该类实现了桥接接口,并提供了具体的实现。 4. 在抽象类定义一个抽象方法,该方法将调用桥接接口的方法。 5. 创建一个扩展抽象类,该类扩展了抽象类,并实现了抽象方法。 6. 在扩展抽象类实现抽象方法,该方法将调用桥接接口的方法。 下面是一个简单的Java桥接模式示例代码: ```java // 定义桥接接口 interface DrawAPI { public void drawCircle(int radius, int x, int y); } // 创建实现类 class RedCircle implements DrawAPI { public void drawCircle(int radius, int x, int y) { System.out.println("Drawing Circle[ color: red, radius: " + radius + ", x: " + x + ", " + y + "]"); } } // 创建抽象类 abstract class Shape { protected DrawAPI drawAPI; protected Shape(DrawAPI drawAPI){ this.drawAPI = drawAPI; } public abstract void draw(); } // 创建扩展抽象类 class Circle extends Shape { private int x, y, radius; public Circle(int x, int y, int radius, DrawAPI drawAPI) { super(drawAPI); this.x = x; this.y = y; this.radius = radius; } public void draw() { drawAPI.drawCircle(radius,x,y); } } // 使用桥接模式 public class BridgePatternDemo { public static void main(String[] args) { Shape redCircle = new Circle(100,100, 10, new RedCircle()); redCircle.draw(); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 24
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值