–> JAVA SE (9)
重写(Override)/重载(Overload)
重写
重写规则:
子类对父类允许访问的方法的方法的实现过程进行重新编写,但是,返回值和形参都不能改变。
另外:
- 访问权限比不能比父类低(父类是public,则子类只能是public)
- 声明为static的方法不能被重写,但是能被在此声明
- 子类和父类在同一个包中,可以写重写所有方法(除了private和final修饰的)
- 子类和父类不在一个包中,子类只能重写public和protected修饰的非final方法
注意:重写的方法,不能抛出新的检查异常,或者比重写的方法声明更宽泛的异常。
class Animal{
public void move(){
System.out.println("动物可以移动");
}
}
class Dog extends Animal{
public void move(){
System.out.println("狗可以跑和走");
}
}
public class TestDog{
public static void main(String args[]){
Animal a = new Animal(); // Animal 对象
Animal b = new Dog(); // Dog 对象
a.move();// 执行 Animal 类的方法
b.move();//执行 Dog 类的方法
}
}
结果:
动物可以移动
狗可以跑和走
注意:虽然b属于Animal类,但是运行的是Dog类的move方法。因为,在编译阶段,只检查参数的引用类型(编译成功是因为Animal类中也存在move方法,不存在则不能通过编译),但是在运行时,虚拟机指定对象的类型并且运行该对象的方法。
如下:
class Animal{
public void move(){
System.out.println("动物可以移动");
}
}
class Dog extends Animal{
public void move(){
System.out.println("狗可以跑和走");
}
public void bark(){
System.out.println("狗可以吠叫");
}
}
public class TestDog{
public static void main(String args[]){
Animal a = new Animal(); // Animal 对象
Animal b = new Dog(); // Dog 对象
a.move();// 执行 Animal 类的方法
b.move();//执行 Dog 类的方法
b.bark();
}
}
结果
Exception in thread "main" java.lang.Error: Unresolved compilation problem:
The method bark() is undefined for the type Animal
at binaryheap.test.BH.main(BH.java:32)
程序抛出一个编译错误,b的引用类型是Animal,但是Animal中并没有bark()方法。
重载
发生在一个类里,方法名字相同,参数不同。两同一不同:同类同名不同参。
注意:返回类型无所谓,可以相同也可以不同。
因此重载规则:
- 重载方法必须改变参数列表-类型或者数目
- 不以返回值作为重载的区分标准
重载和重写两者的区别:
- 重写是发生在父类和子类之间,而重载发生在同一个类中;
- 重写时,父类的子类的方法名、参数个数和类型、返回值也一样,反应父子差异;但是重载时,方法名相同、类名相同,参数个数和类型不同,反应“”随机应变“”。因此,两者的区别还是挺大的。通过参数即可区分两者。
多态
多态:同一个行为有多个不同表现形式。同一个接口,使用不同的实例从而执行不同的操作。
详见封装继承多态