这个和JVM实现关系不大,是否为native方法也没关系。这是java特性-多态的一种体现,重写之后调用的实际上是实现类的hashCode方法,和超类的hasCode方法没关系了(如果实现类没调用超类的hashCode方法的话)
abstract class A{
int hasCode(){
}
}
class B extend A{
int hasCode(){
//我实现了
}
}
A a = new B();
a.hasCode(); // 实际上此时a引用的B的实例,a.hasCode()重写了A中的hashCode,调用的实际上是重写后的方法。