java什么是方法的重写?java中方法重写具体是什么
大家好,今天小编来为大家解答java什么是方法的重写这个问题,java中方法重写具体是什么很多人还不知道,现在让我们一起来看看吧!
java什么是方法重写的语法规则
一、方法的重写。
1、重写只能出现在继承关系之中。当一个类继承它的父类方法时,都有机会重写该父类的方法。一个特例是父类的方法被标识为final。重写的主要优点是能够定义某个子类型特有的行为。
class Animal{
public void
eat(){
System.out.println("Animal is eating.");
}
}
class Horse extends Animal{
public void eat(){
System.out.println("Horse is
eating.");
}
}
2、对于从父类继承来的抽象方法,要么在子类用重写的方式设计该方法,要么把子类也标识为抽象的。所以抽象方法可以说是必须要被重写的方法。
3、重写的意义。
重写方法可以实现多态,用父类的引用来操纵子类对象,但是在实际运行中对象将运行其自己特有的方法。
public class Test{
public static
void main(String[] args){
Animal h= new Horse();
h.eat();
}
}
class Animal{
public void eat(){
System.out.println("Animal is
eating.");
}
}
class Horse extends
Animal{
public void
eat(){
System.out.println("Horse is eating.");
}
public void
buck(){
}
}
一个原则是:使用了什么引用,编译器就会只调用引用类所拥有的方法。如果调用子类特有的方法,如上例的h.buck();
编译器会抱怨的。也就是说,编译器只看引用类型,而不是对象类型。
4、重写方法的规则。
若想实现一个合格重写方法,而不是重载,那么必须同时满足下面的要求!
重写规则之一:重写方法不能比被重写方法限制有更严格的访问级别。
(但是可以更广泛,比如父类方法是包访问权限,子类的重写方法是public访问权限。)
比如:Object类有个toString()方法,开始重写这个方法的时候我们总容易忘记public修饰符,编译器当然不会放过任何教训我们的机会。出错的原因就是:没有加任何访问修饰符的方法具有包访问权限,包访问权限比public当然要严格了,所以编译器会报错的。
重写规则之二:参数列表必须与被重写方法的相同。
重写有个孪生的弟弟叫重载,也就是后面要出场的。如果子类方法的参数与父类对应的方法不同,那么就是你认错人了,那是重载,不是重写。
重写规则之三:返回类型必须与被重写方法的返回类型相同。
父类方法A:void
eat(){}子类方法B:int eat(){}两者虽然参数相同,可是返回类型不同,所以不是重写。
父类方法A:int
eat(){}子类方法B:long eat(){}
返回类型虽然兼容父类,但是不同就是不同,所以不是重写。
重写规则之四:重写方法不能抛出新的异常或者比被重写方法声明的检查异常更广的检查异常。但是可以抛出更少,更有限或者不抛出异常。
例:
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及其子类不再这个限制之中。
重写规则之五:不能重写被标识为final的方法。
重写规则之六:如果一个方法不能被继承,则不能重写它。
比较典型的就是父类的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的啊!应该可以调用啊!请牢记,多态只看父类引用的方法,而不看子类对象的方法!
什么是方法重写
方法重写是面向对象编程中的一种特性,指的是在子类中重新定义父类中已有的方法,使其具有不同的实现方式和行为。
在Java等编程语言中,方法重写是实现多态性的一种重要方式。当子类继承了父类并且需要修改继承自父类的方法实现时,就需要使用方法重写。
对于子类中的方法重写,它们必须与从父类继承方法,继承过来的方法有相同的名称、返回类型和参数列表。子类中的重写方法可以包含不同的实现细节、逻辑和业务规则,因此可以根据具体的需求实现各种不同的功能。当需要在父类中定义一个通用的方法,但某些子类需要针对自己的特定需求进行具体的实现时,就可以利用重写方法来满足这些需求。
在方法重写中,若子类中的方法与父类中的某个方法的名称、返回类型和参数列表不一致,则不是方法重写,而是方法重载。此时,子类中的方法与父类中的方法是两个不同的方法,它们具有不同的签名和实现细节。
重载方法的含义:
重载方法必须与其他重载方法在方法名称方面相同,但在参数数量、参数类型或两者都相同时,可以采用不同的方式实现。例如,可以在一个类中创建多个名为print的方法,其分别接受不同类型和数量的参数。
当调用重载方法时,编译器将根据传递给该方法的参数数量和类型来确定要调用哪个重载方法。例如,如果用户调用了带有double类型参数的print方法,编译器将搜索以print命名且只有一个double类型参数的重载版本,并调用它。
方法重载在处理不同类型的数据时非常有用。通过使用方法重载,用户可以轻松地处理各种类型的数据,而无需编写大量的逻辑代码。此外,方法重载是提高代码的可读性和可维护性的一种方式,让代码更加简洁和易于理解。
以上内容参考:百度百科—方法重写
java中方法的覆写和重写是否一样
“覆写”和“重写”是一样的,还有叫“覆盖”的,都是override,意思就是父类和子类中的同名同参数的方法,它们之间的关系就是,子类的方法把父类的方法给盖住了(其实不一定是父类,父接口也可以)。
比如动物是父类,人是子类,都有奔跑run()这个方法,人类能够不用四肢在地上奔跑,所以应该重写run()这个方法,让人类直立行走啊!
注意要和另一种区分的就是“重载”,即overload,这是同一个类中同名不同参的方法,它们之间的关系就是,你调用同一个名字,但是传递的是不同的参数,
比如求和sum方法,可以对int类型求和,也可以对double类型求和,这两个方法作用相同,所以起同样的名字。因此sum(int int)和sum(double, double)就是两个重载方法。
java中方法重写具体是什么
方法覆盖 Override方法重写:
发生在有继承关系的两个类之间子类类型当中.要求:完全符合《进化论》
方法不要看其长短
修饰符返回类型方法名字(参数列表)异常声明{}
头|躯干(方法签名)|尾巴
不能更小必须相同不能更大
也就是:
访问控制权限修饰符不能更加严格
返回类型+方法名+参数列表必须相同
异常声明不能更加广泛
OK,本文到此结束,希望对大家有所帮助。