1.重写方法的方法名和参数列表要和被重写方法一致。
2.在 java 1.4版本以前,重写方法的返回值类型被要求必须与被重写方法一致,但是在java 5.0中放宽了这一个限制,添加了对协变返回类型的支持,在重写的时候,重写方法的返回值类型可以是被重写方法返回值类型的子类。
示例代码如下:
class A{
public Object test(){
return null;
}
}
class B extends A{
public String test(){
return null;
}
}
但是,对于基本数据类型,由于它们不是类,所以不能实现协变返回类型,但是使用对用的包装类则可以。
3.重写方法不能使用比被重写方法更严格的权限,即重写方法的权限要大于或者等于被重写方法的权限。上面的代码如果改写成下面的样子将不能通过编译。
class A{
public Object test(){
return null;
}
}
class B extends A{
private String test(){
return null;
}
}
访问权限表:
修饰符 | 同一个类中 | 同一个包中 | 子类 | 不同包中 |
---|---|---|---|---|
public | Yes | Yes | Yes | Yes |
protected | Yes | Yes | Yes | |
default | Yes | Yes | ||
private | Yes |
4.private修饰不支持继承,所以无法重写private修饰的方法。static修饰的方法也不能被重写。虽然在子类中可以存在与父类中private方法和static方法相同名称的方法,但是并不存在多态,所以并不是重写。
示例代码:
class Father{
private void method(){
System.out.println("父类的private方法");
}
static void staticMethod(){
System.out.println("父类的static方法");
}
public static void main(String[] args){
Father son = new Son();
son.method();
son.staticMethod();
Son son1 = new Son();
son1.method();
son1.staticMethod();
}
}
class Son extends Father{
public void method(){
System.out.println("子类的private方法");
}
static void staticMethod(){
System.out.println("子类的static方法");
}
}
运行结果是:
5.重写方法声明抛出的异常不能比被重写方法宽泛,即不抛出异常或者抛出被重写方法中抛出异常的子类。