重载(Overload)和重写(Override)
方法的重载和重写都是实ava多态性的不同表现,重载可以理解成多态的具体表现形式,重写是父类与子类之间多态性的一种表现,区别在于前者实现的是编译时的多态性,而后者实现的是运行时的多态性。
重载(Overload)
重载发生在一个类中,同名的方法如果有不同的参数列表(参数类型不同、参数个数不同或者二者都不同)则视为重载;
每个重载的方法(或者构造函数)都必须有一个独一无二的参数类型列表。
重载规则
- 被重载的方法必须改变参数列表(参数个数或类型或顺序不一样);
- 被重载的方法可以改变返回类型;
- 被重载的方法可以改变访问修饰符;
- 被重载的方法可以声明新的或更广的检查异常;
- 方法能够在同一个类中或者在一个子类中被重载。
- 重载对返回类型没有特殊的要求,无法以返回值类型作为重载函数的区分标准
- 重载是同样的一个方法写多次变量修饰符不一样,当调用方法时,会自动判断给入数的类型,选取其中符合的方法。
-
public class Overloading {
输出结果:
private static int i = 5;
private static double l = 3.1415;
private static String k = "我是小白";
//参数类型不同
public int test(){
System.out.println("我是空参数");
return 1;
}
public void test(int a){
System.out.println("你输入了整数:"+a);
}
public void test(double a){
System.out.println("你输入了浮点数:"+a);
}
public void test(String a){
System.out.println("你输入了字符串:"+a);
}
//以下两个参数类型顺序不同
public String test(int a,String s){
System.out.println("test3");
return "returntest3";
}
public String test(String s,int a){
System.out.println("test4");
return "returntest4";
}
public static void main(String[] args){
Overloading lizi = new Overloading();
lizi.test();
lizi.test(i);
lizi.test(l);
lizi.test(k);
System.out.println(lizi.test(1,"test3"));
System.out.println(lizi.test("test4",1));
}
} -
我是空参数
你输入了整数:5
你输入了浮点数:3.1415
你输入了字符串:我是小白
test3
returntest3
test4
returntest4
重写(Override)
重写发生在子类与父类之间,重写要求子类被重写方法与父类被重写方法有相同的方法名、相同的返回类型,参数列表中,参数的个数、顺序、类型必须一样,比父类被重写方法更好访问,不能比父类被重写方法声明更多的异常(里氏代换原则)。
使用被重写的方法时,该方法满足就近调用的原则
方法的重写规则
- 参数列表必须完全与被重写方法的相同;
- 返回类型必须完全与被重写方法的返回类型相同;
- 访问权限不能比父类中被重写的方法的访问权限更低。例如:如果父类的一个方法被声明为public,那么在子类中重写该方法就不能声明为protected。
- 父类的成员方法只能被它的子类重写。
- 声明为final的方法不能被重写。
- 声明为static的方法不能被重写,但是能够被再次声明。
- 子类和父类在同一个包中,那么子类可以重写父类所有方法,除了声明为private和final的方法。
- 子类和父类不在同一个包中,那么子类只能够重写父类的声明为public和protected的非final方法。
- 重写的方法能够抛出任何非强制异常,无论被重写的方法是否抛出异常。但是,重写的方法不能抛出新的强制性异常,或者比被重写方法声明的更广泛的强制性异常,反之则可以。
- 构造方法不能被重写。
- 如果不能继承一个方法,则不能重写这个方法。