public class DynamicBindingDemo {
public static void main(String[] args) {
m(new GraduateStudent());
m(new Student());
m(new Person());
m(new Object());
}
public static void m(Object x) {
System.out.println(x.toString());
}
}
class GraduateStudent extends Student {
}
class Student extends Person {
public String toString() {
return "student";
}
}
class Person extends Object {
public String toString() {
return "Person";
}
}
student
student
Person
java.lang.Object@9e3fc2
/** 动态绑定工作机制如下:假设对象o 是类C1,C2,。。。,Cn-1,Cn
的实例,其中C1是C2的子类,C2是C3的子类,。。。,Cn-1是Cn的子类。
也就是说,Cn是最通用的类,C1是最特殊的类。在java中,Cn是Object 类。
如果对象o 调用一个方法p,那么Java虚拟机会依次在类C1,C2,。。。,
Cn-1,Cn中查找方法p 的实现,直到找到为止。一旦找到一个实现,就停止查找
然后调用这个第一次找到的实现
匹配方法的签名和绑定方法的实现是两个独立的事情。引用变量的声明类型决定了
编译时匹配哪个方法。编译器会在编译时,根据参数类型、参数个数和参数顺序找到
匹配方法。一个方法可能在几个子类中都被实现。Java虚拟机在运行时动态绑定
方法的实现,这是由变量的实际类型决定的
*/
public static void main(String[] args) {
m(new GraduateStudent());
m(new Student());
m(new Person());
m(new Object());
}
public static void m(Object x) {
System.out.println(x.toString());
}
}
class GraduateStudent extends Student {
}
class Student extends Person {
public String toString() {
return "student";
}
}
class Person extends Object {
public String toString() {
return "Person";
}
}
student
student
Person
java.lang.Object@9e3fc2
/** 动态绑定工作机制如下:假设对象o 是类C1,C2,。。。,Cn-1,Cn
的实例,其中C1是C2的子类,C2是C3的子类,。。。,Cn-1是Cn的子类。
也就是说,Cn是最通用的类,C1是最特殊的类。在java中,Cn是Object 类。
如果对象o 调用一个方法p,那么Java虚拟机会依次在类C1,C2,。。。,
Cn-1,Cn中查找方法p 的实现,直到找到为止。一旦找到一个实现,就停止查找
然后调用这个第一次找到的实现
匹配方法的签名和绑定方法的实现是两个独立的事情。引用变量的声明类型决定了
编译时匹配哪个方法。编译器会在编译时,根据参数类型、参数个数和参数顺序找到
匹配方法。一个方法可能在几个子类中都被实现。Java虚拟机在运行时动态绑定
方法的实现,这是由变量的实际类型决定的
*/