一,什么是方法的重写(override 或 overwrite)?
子类继承父类以后,可以对父类中同名同参数的方法,进行覆盖操作。
1.1 应用:
重写以后,当创建子类对象以后,通过子类对象调用子父类中的同名同参数的方法时,实际执行的是子类重写父类的方法。
(但还可用super.方法
调用父类被重写的方法)
1.2 重写的规则
方法的声明:
权限修饰符 返回值类型 方法名(形参列表) throws 异常的类型{
方法体
}
约定俗称:子类中的叫重写的方法,父类中的叫被重写的方法
- 子类重写的方法的方法名和形参列表与父类被重写的方法的方法名和形参列表相同。
- 子类重写的方法的权限修饰符不小于父类被重写的方法的权限修饰符。
特殊情况: 子类不能重写父类中声明为private
权限的方法 - 返回值类型:
- 父类被重写的方法的返回值类型是void,则子类重写的方法的返回值类型必须也是void。
- 父类被重写的方法的返回值类型是A类型,则子类重写的方法的返回值类型可以是A类或A类的子类。
- 父类被重写的方法的返回值类型是基本数据类型(比如:double),则子类重写的方法的返回值类型必须是相同的基本数据类型(必须也是double)。
- 子类重写的方法抛出的异常类型不大于父类被重写的方法抛出的异常类型。
附: 子类和父类中的同名同参数的方法
- 要么都声明为非static的。(考虑重写)
- 要么都声明为static的。(不是重写)
二,什么是方法的重载?
定义:在同一个类中,允许存在一个以上的同名方法,只要它们的参数个数或者参数类型不同即可。
总结:“两同一不同”:同一个类、相同方法名。 参数列表不同:参数个数不同,参数类型不同
2.1 构成重载的举例:
举例一:
Arrays类中重载的sort() / binarySearch();PrintStream中的println()
举例二:
//如下的4个方法构成了重载
public void getSum(int i,int j){
System.out.println("1");
}
public void getSum(double d1,double d2){
System.out.println("2");
}
public void getSum(String s ,int i){
System.out.println("3");
}
public void getSum(int i,String s){
System.out.println("4");
}
2.2 如何判断是否构成方法的重载?
严格按照定义判断:两同一不同。
跟方法的权限修饰符、返回值类型、形参变量名、方法体都没关系!
2.3 .如何确定类中某一个方法的调用:
方法名 —> 参数列表
三,面试题:区分方法的重写和重载?
① 二者的概念,如上。
② 重载和重写的具体规则。如上
③ 重载:不表现为多态性。 重写:表现为多态性。
重载,是指允许存在多个同名方法,而这些方法的参数不同。编译器根据方法不同的参数表,对同名方法的名称做修饰。对于编译器而言,这些同名方法就成了不同的方法。它们的调用地址在编译期就绑定了。Java的重载是可以包括父类和子类的,即子类可以重载父类的同名不同参数的方法。
所以:对于重载而言,在方法调用之前,解释运行器就已经确定了所要调用的方法,这称为==“早绑定”或“静态绑定”==;
而对于多态,只等到方法调用的那一刻,解释运行器才会确定所要调用的具体方法,这称为==“晚绑定”或“动态绑定”==。
引用一句Bruce Eckel的话:“不要犯傻,如果它不是晚绑定,它就不是多态。”