1.JVM 字节码 对照表
https://blog.csdn.net/u013294097/article/details/103747429/
2.查看字节码(.class)文件
在Idea的terminal中找到.class文件所在位置;
javap -v 类名.class 查看;
(如果是没有编译的,进入到类所在文件夹,javac 类名.java 编译一下,然后重复上面的步骤)
3.静态类型和实际类型
Human man =new Man();
Human称为变量的静态类型,后面的Man是变量的实际类型。
4.方法表(虚函数表)
每个类对应一个方法表
子类方法表中包含父类方法表中的所有方法,子类方法在方法表中的索引值,与它所重写的父类方法的索引值相同
案例:https://blog.csdn.net/Herishwater/article/details/123180498
5.方法执行与方法调用
方法入栈的执行过程
局部变量存储及运算
方法绑定
字节码解析案例:https://blog.csdn.net/yx444535180/article/details/114023333
6.向上转型中属性和方法的调用规则(结论不完全正确,欢迎指正)
参考(jvm分析):https://blog.csdn.net/weixin_43712120/article/details/123127301
个人理解纠正:
重写后的方法在Son类方法表中只存了一份;(参考中Son类方法表有错误)
向上转型后查找的其实都是son对象中的父类方法、父类属性;
由于父类方法重写过,Son方法表中该父类方法是保存的重写后的方法地址;
总结:向上转型后,调用的属性和方法都是父类的,只是方法重写后方法表中的方法地址被覆盖了,所以才调用到了子类方法。其实子类独有方法也是存在于方法表的,因为父类中不存在该方法,所以导致无法调用。向下转型同理,都是调用的子类属性和方法。(个人理解的“编译看左边,运行看右边”)