JVM实战-掌握分派方法规则

方法调用问题

java 复制代码
class GrandFather {
void thinking() {
	System.out.println("i am grandfather");
	}
}
class Father extends GrandFather {
	void thinking() {
		System.out.println("i am father");
	}
}
class Son extends Father {
	void thinking() {
	// 请读者在这里填入适当的代码(不能修改其他地方的代码)
	// 实现调用祖父类的thinking()方法,打印"i am grandfather"
	}
}

Java程序中,可以通过"super"关键字很方便地调用到父类中的方法,但如何访问祖类的方法

使用MethodHandles

java 复制代码
void thinking() {
try {
	MethodType mt = MethodType.methodType(void.class);
	Field lookupImpl = MethodHandles.Lookup.class.getDeclaredField("IMPL_LOOKUP");
	lookupImpl.setAccessible(true);
	MethodHandle mh = ((MethodHandles.Lookup) lookupImpl.get(null)).findSpecial(GrandFather.class,"thinking", mt, 			GrandFather.class);
	mh.invoke(this);
} catch (Throwable e) {
}
}

基于栈的字节码解释执行引擎

执行引擎

基于栈的指令集与基于寄存器的指令集

Javac编译器输出的字节码指令流,基本上[1]是一种基于栈的指令集架构(Instruction SetArchitecture,ISA),字节码指令流里面的指令大部分都是零地址指令,它们依赖操作数栈 进行工作。

基于栈的指令集主要优点是可移植 ,因为寄存器由硬件直接提供,程序直接依赖这些硬件寄存器则不可避免地要受到硬件的约束。栈架构指令集的主要缺点是理论上执行速度相对来说会稍慢一些

基于栈的解释器执行过程

示例字节码

java 复制代码
public int calc();
	Code:
		Stack=2, Locals=4, Args_size=1
		0: bipush 100
		2: istore_1
		3: sipush 200
		6: istore_2
		7: sipush 300
		10: istore_3
		11: iload_1
		12: iload_2
		13: iadd
		14: iload_3
		15: imul
		16: ireturn
}

操作数入栈 遇到符号出栈计算

相关推荐
铁锚23 分钟前
JDK21与lombok插件的兼容性问题
jvm·maven
qq_377112373 小时前
JAVA的平凡之路——此峰乃是最高峰JVM-GC垃圾回收器(1)-06
java·开发语言·jvm
熊猫吃竹子3 小时前
JVM G1GC参数调优实战
jvm·后端
qq_377112374 小时前
JAVA的平凡之路——此峰乃是最高峰JVM-GC垃圾回收器(2)-06
java·开发语言·jvm
深圳佛手6 小时前
Java大对象(如 List、Map)如何复用?错误的方法是?正确的方法是?
java·jvm·windows
想学后端的前端工程师17 小时前
【深入理解JVM内存模型与垃圾回收机制】
jvm
tryxr19 小时前
volatile 的作用
java·jvm·volatile·指令重排序
Knight_AL20 小时前
深入解析 JVM 垃圾回收算法:经典 vs 新型 GC 算法
jvm·算法
猿饵块21 小时前
python--锁
java·jvm·python
历程里程碑1 天前
C++ 17异常处理:高效捕获与精准修复
java·c语言·开发语言·jvm·c++