java方法覆写_【JAVA】java方法覆写规则

本文介绍了Java方法重写的六大规则。包括重写方法访问级别不能更严格、参数列表和返回类型要相同、不能抛出更广的检查异常、不能重写final方法、不能重写不可继承的方法等,还通过代码示例进行说明,强调了多态只看父类引用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

A、重写规则之一:

重写方法不能比被重写方法限制有更严格的访问级别。 (但是可以更广泛,比如父类方法是包访问权限,子类的重写方法是public访问权限。)

比如:Object类有个toString()方法,开始重写这个方法的,时候我们总容易忘记public修饰符,编译器当然不会放过任何教训我们 的机会。出错的原因就是:没有加任何访问修饰符的方法具有包访问权限,包访问权限比public当然要严格了,所以编译器会报错的。

B、重写规则之二:

参数列表必须与被重写方法的相同。 重写有个孪生的弟弟叫重载,也就是后面要出场的。如果子类方法的参数与父类对应的方法不同,那么就是你认错人了,那是重载,不是重写。

C、重写规则之三:

返回类型必须与被重写方法的返回类型相同。

父类方法A:void eat(){} 子类方法B:int eat(){} 两者虽然参数相同,可是返回类型不同,所以不是重写。 父类方法A:int eat(){} 子类方法B:long eat(){} 返回类型虽然兼容父类,但是不同就是不同,所以不是重写。

D、重写规则之四:

重写方法不能抛出新的异常或者比被重写方法声明的检查异常更广的检查异常。但是可以抛出更少,更有限或者不抛出异常。

1 import java.io.*;2

3 public class Test {4     public static voidmain (String[] args){5       Animal h = newHorse();6       try{7 h.eat();8       } catch(Exception e) {9

10 }11 }12 }13

14 class Animal {15     public voideat()16 throws Exception{17       System.out.println ("Animal is eating.");18       throw newException();19 }20 }21

22 class Horse extends Animal{23     public voideat()24

25 throws IOException{26       System.out.println ("Horse is eating.");27       throw newIOException();28 }29   }

这个例子中,父类抛出了检查异常Exception,子类抛出的IOException是Exception的子类,也即是比被重写的方法抛出了 更有限的异常,这是可以的。如果反过来,父类抛出IOException,子类抛出更为宽泛的Exception,那么不会通过编译的。

注意:这种限制只是针对检查异常,至于运行时异常RuntimeException及其子类不再这个限制之中。

E、重写规则之五:

不能重写被标识为final的方法。

F、重写规则之六:

如果一个方法不能被继承,则不能重写它。 比较典型的就是父类的private方法。

下例会产生一个有趣的现象。

1 public class Test {2     public static voidmain (String[] args) {3       //Animal h = new Horse();

4       Horse h = newHorse();5 h.eat();6 }7 }8

9 class Animal {10     private voideat(){11       System.out.println ("Animal is eating.");12 }13 }14

15 class Horse extends Animal{16     public voideat(){17       System.out.println ("Horse is eating.");18 }19   }

这段代码是能通过编译的。表面上看来违反了第六条规则,但实际上那是一点巧合。Animal类的eat()方法不能被继承,因此Horse类中的 eat()方法是一个全新的方法,不是重写也不是重载,只是一个只属于Horse类的全新的方法!这点让很多人迷惑了,但是也不是那么难以理解。

main()方法如果是这样: Animal h = new Horse(); //Horse h = new Horse(); h.eat(); 编译器会报错,为什么呢?Horse类的eat()方法是public的啊!应该可以调用啊!

这里就牵扯到一个向上转型的概念了,当父类引用了子类的一个实例时,子类复写了父类的方法会覆盖父类中相同的方法,但子类中有而父类中没有的方法父类就无法调用。在这个例子中,由于Animal中的eat方法是private的,所以子类中的eat方法不算复写了父类的eat方法,这是一个新方法,所以调用父类的eat方法时,就无法调用子类的eat方法,而父类的eat方法为private,所以发生了错误。

请牢记,多态只看父类引用的方法,而不看子类对象的方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值