java重写需要满足的条件

原文地址:http://tju-zhangj.iteye.com/blog/661291

若想实现一个合格重写方法,而不是重载,那么必须同时满足下面的要求! 


A、重写规则之一:重写方法不能比被重写方法限制有更严格的访问级别。 
(但是可以更广泛,比如父类方法是包访问权限,子类的重写方法是public访问权限。) 
比如:Object类有个toString()方法,开始重写这个方法的时候我们总容易忘记public修饰符,编译器当然不会放过任何教训我们的机会。出错的原因就是:没有加任何访问修饰符的方法具有包访问权限,包访问权限比public当然要严格了,所以编译器会报错的。 

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

C、重写规则之三:返回类型必须与被重写方法的返回类型相同。 
父类方法A:void eat(){} 子类方法B:int eat(){} 两者虽然参数相同,可是返回类型不同,所以不是重写。 
父类方法A:int eat(){}   子类方法B:long eat(){} 返回类型虽然兼容父类,但是不同就是不同,所以不是重写。 

D、重写规则之四:重写方法不能抛出新的异常或者比被重写方法声明的检查异常更广的检查异常。但是可以抛出更少,更有限或者不抛出异常。 
   import java.io.*; 
   public class Test { 
       public static void main (String[] args) { 
           Animal h = new Horse(); 
           try { 
               h.eat();   
           } 
           catch (Exception e) { 
           } 
       } 
   } 

   class Animal { 
       public void eat() throws Exception{ 
           System.out.println ("Animal is eating."); 
           throw new Exception(); 
       } 
   } 
   
   class Horse extends Animal{ 
       public void eat() throws IOException{ 
           System.out.println ("Horse is eating."); 
           throw new IOException(); 
       } 
   } 
这个例子中,父类抛出了检查异常Exception,子类抛出的IOException是Exception的子类,也即是比被重写的方法抛出了更有限的异常,这是可以的。如果反过来,父类抛出IOException,子类抛出更为宽泛的Exception,那么不会通过编译的。 
注意:这种限制只是针对检查异常,至于运行时异常RuntimeException及其子类不再这个限制之中。 

E、重写规则之五:不能重写被标识为final的方法。 

F、重写规则之六:如果一个方法不能被继承,则不能重写它。 
比较典型的就是父类的private方法。下例会产生一个有趣的现象。 
   public class Test { 
       public static void main (String[] args) { 
           //Animal h = new Horse(); 
           Horse h = new Horse(); 
           h.eat(); 
       } 
   } 

   class Animal { 
       private void eat(){ 
           System.out.println ("Animal is eating."); 
       } 
   } 
   
   class Horse extends Animal{ 
       public void eat(){ 
           System.out.println ("Horse is eating."); 
       } 
   } 
这段代码是能通过编译的。表面上看来违反了第六条规则,但实际上那是一点巧合。Animal类的eat()方法不能被继承,因此Horse类中的eat()方法是一个全新的方法,不是重写也不是重载,只是一个只属于Horse类的全新的方法!这点让很多人迷惑了,但是也不是那么难以理解。 
main()方法如果是这样: 
   Animal h = new Horse(); 
   //Horse h = new Horse(); 
   h.eat(); 
编译器会报错,为什么呢?Horse类的eat()方法是public的啊!应该可以调用啊!请牢记,多态只看父类引用的方法,而不看子类对象的方法!
  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java方法重写是指在子类中重新定义与其父类中具有相同名称、参数类型和返回值类型的方法的过程。重写方法的条件如下: 1. 方法名与参数列表必须与被重写方法的方法名和参数列表完全相同。 2. 返回类型必须与被重写方法的返回类型相同或者是其子类。 3. 访问修饰符不能比被重写方法的修饰符更严格。比如,如果父类中的方法为public,则子类中的该方法也必须为public,或者更为宽松的访问权限,而不是protected或private。 4. 子类中抛出的异常类型必须与被重写方法的异常类型相同或者是其子类。 5. 被重写的方法不能是private类型。 6. 静态方法不能被重写,但可以被隐藏。 7. final方法不能被重写。 通过符合以上条件的方法重写,实现子类对父类方法的扩展和优化,提高代码的可重用性和扩展性,同时也更好地满足了OOP的封装、继承和多态原则。 ### 回答2: Java中的方法重写指的是子类中重新定义和父类中已有的方法具有相同名称和参数,并且具有相同的返回类型或者是返回类型为子类的情况下的重写过程。 在Java中,方法重写需要满足以下条件: 1. 方法名必须相同 重写的方法名必须与父类中要被重写的方法名称相同,包括大小写。 2. 方法参数必须相同 重写的方法必须与被重写的方法的形式参数列表相同。如果两个方法的参数不同,那么它们就是两个不同的方法。 3. 方法返回值必须相同或者是父类方法返回值的子类 重写的方法返回值必须与被重写的方法的返回值类型相同或者是其类型的子类。父类中方法的返回值类型如果是基本数据类型,则重写的方法的返回值类型一定要和其相同。 4. 访问修饰符必须相同 Java中的方法访问修饰符有public、protected、private和默认访问修饰符四种,重写的方法访问修饰符必须与被重写的方法的访问修饰符相同或者是更加宽松的访问修饰符。 5. 异常类型必须相同或者是子集 重写的方法声明抛出的异常类型必须和被重写的方法声明抛出的异常类型相同或者是其类型的子集。如果被重写的方法没有声明任何异常,那么重写的方法也不能声明异常。 总之,方法重写Java多态性的一种体现,它允许子类在不改变父类已有同名方法的情况下,重新定义已有的方法,来满足子类的需要。但需要注意的是,重写方法时需要遵循以上的条件。 ### 回答3: Java方法重写条件主要有四点,分别是方法名、 参数列表、返回类型和访问修饰符。 首先,方法名必须与被重写方法的名称完全相同。其次,参数列表也必须与被重写方法的相同。参数列表应该有相同的参数顺序、类型和数量。如果参数类型或参数顺序不同,则不是方法的重写而是方法的重载。同时,返回类型应该与被重写方 法的返回类型相同或者是其子类,返回类型可以是原始类型或者是对象类型。如果返回类型不同,则不符合方法的重写条件。最后,访问修饰符也应该相同或者更为宽松。如果子类中所重写的方法的访问修饰符比父类中被重写的方法的访问修饰符更为严格,就不能表现出继承的特性,从而不能实现方法的重写需要注意的是,对于静态方法,不能被覆盖,只能隐藏,因为方法的调用是基于类而非对象的。因此,对于静态方法的方法签名,不能被更改,否则会编译错误。此外,私有方法也无法被重写,因为私有方法只在本类中使用。 总之,上述四个条件Java方法重写的必要条件满足这些条件才能成功实现方法重写,发挥出Java的面向对象的优势。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值