public class father {
private int num ;
private String name;
private int salary;
public void getSalary() {return salary;}
public int print_num(int num1,int num2){return num1+num2;}
public String getName(){return name;}
}
public class son extends father {
private int bonus;
public int getSalary(){return super.getSalary()+bonus;}
public int print_num(int num){return num;}
public String print_num(String num ){return num;}
}
程序运行时,虚拟机会预先为每个类创建一个方法表
father:
getSalary() -> father.getSalary()
print_num(int,int) ->father.print_num(int,int)
getName() -> father.getName()
son:
getSalary() ->son.getSalary()
print_num(int) ->son.print_num(int)
print_num(String) ->son.print_num(String)
1).编译器查看对象上的声明类型和方法名,如无重载,将率先使用指定类型的方法 动态绑定
例如声明一个son的对象A,使用A来调用方法时会首先使用son类中的方法
A.getSalary();
//会调用son.getSalary(),不考虑father.getSalary()
2).可能存在重载(多个名字相同,但参数类型不一样的方法),此时就将考虑所有的方法(包括超类访问属性为public的方法)。根据参数来调用 重载解析
A.print_num(1,3);
//将使用超类中的方法father.print_num(int,int)
A.print_num("we");
//调用son.print_num(String)
3). 如果使用的方法在类中没有定义,将在超类中寻找
A.getName();
//调用超类中的方法, father.getName()
4).特殊情况,用private 、static、final修饰的方法,编译器会准确的知道调用哪个方法 静态绑定