重写:
子类继承于父类的非静态方法的方法体进行重新编写, 返回值和形参都不能改变。即外壳不变,核心重写!
注解:
@Override
优势:
子类可以根据需要,定义特定于自己的行为。 也就是说子类能够根据需要实现父类的方法。
规则:
- 参数列表必须完全与被重写方法的相同;
- 返回类型与被重写方法的返回类型可以不相同,但是必须是父类返回值的派生类(java5 及更早版本返回类型要一样,java7 及更高版本可以不同);
- 访问权限不能比父类中被重写的方法的访问权限更低。例如:如果父类的一个方法被声明为public,那么在子类中重写该方法就不能声明为protected。
- 父类的成员方法只能被它的子类重写。
- 声明为final的方法不能被重写。
- 声明为static的方法不能被重写,但是能够被再次声明。
- 子类和父类在同一个包中,那么子类可以重写父类所有方法,除了声明为private和final的方法。
- 子类和父类不在同一个包中,那么子类只能够重写父类的声明为public和protected的非final方法。
- 重写的方法能够抛出任何非强制异常,无论被重写的方法是否抛出异常。但是,重写的方法不能抛出新的强制性异常,或者比被重写方法声明的更广泛的强制性异常,反之则可以。
- 构造方法不能被重写。
- 如果不能继承一个方法,则不能重写这个方法。
案例
案例代码:
package a_com.edu.studyExtendsExtends;
/**
* @class 父类
* @author hzby
*/
class Father {
String name;
public Father() {}
public Father(String name) {
this.name = name;
}
public void fn() {
System.out.println("Father的方法");
}
}
/**
* @class 子类
* @author hzby
*/
class Children extends Father {
int age;
public Children() {}
public Children(int age, String name) {
this.age = age;
this.name = name;
}
@Override
public void fn() {
System.out.println("Children的方法");
}
}
public class studyOverride {
public static void main(String[] agrs) {
Children children = new Children(10, "张三");
children.fn();
}
}
效果:
文章内容引用自菜鸟教程Java 重写(Override)与重载(Overload)