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
}

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

相关推荐
jmxwzy3 小时前
JVM(java虚拟机)
jvm
Maỿbe4 小时前
JVM中的类加载&&Minor GC与Full GC
jvm
人道领域5 小时前
【零基础学java】(等待唤醒机制,线程池补充)
java·开发语言·jvm
小突突突5 小时前
浅谈JVM
jvm
饺子大魔王的男人6 小时前
远程调试总碰壁?局域网成 “绊脚石”?Remote JVM Debug与cpolar的合作让效率飙升
网络·jvm
天“码”行空16 小时前
java面向对象的三大特性之一多态
java·开发语言·jvm
独自破碎E1 天前
JVM的内存区域是怎么划分的?
jvm
期待のcode1 天前
认识Java虚拟机
java·开发语言·jvm
leaves falling1 天前
一篇文章深入理解指针
jvm
linweidong1 天前
C++ 中避免悬挂引用的企业策略有哪些?
java·jvm·c++