一、1.找到操作数栈顶的第一个元素所执行的对象的实际类型,记作C。
2.如果在类型C中找到与常量中的描述符合简单名称都相符的方法,则进行访问权限校验,如果通过则放回这个方法的直接引用,查找过程结束;如果不通过,则返回java.lang.IllegalAccessError异常。
3,否则,按照继承关系从下往上依次对C的父类进行第2步的搜索和验证过程。
4.如果始终没有找到合适的方法,则抛出java.lang.AbstractMethodError异常。
二、为了避免从下往上依次对C的父类进行第2步的搜索和验证的过程,从而引出虚方法表。
1.在面向对象的编程中,会很频繁的使用到动态分派,如果在每次动态分派的过程中都要重新在类的方法元数据中搜索合适的目标的话可能影响到执行效率,因此为了提高性能,JVM采用在类的方法区中建立一个虚方法表来实现。使用索引表来替代查找。
2.每个类中都有一个虚方法表,表中存放着各个方法的实际入口。
3,虚方法表什么时候被创建。
虚方法表会在类加载的链接阶段被创建并开始初始化,类的变量初始值准备完成后,jvm会把该类的方法表也被初始话完毕。
eg 虚方法表的例子:
Father 重写了 hardChoice(QQ) 和hardChoice(_360) 在虚方法表中指向Father,其他没重写的指向Object,Son的虚方法表中也是如此。