重写java
❶ java中重载和重写的区别是什么
重载: 发生在同一个类中,方法名必须相同,参数类型不同、个数不同、顺序不同,方法返回值和访问修饰符可以不同,发生在编译时。
重写: 发生在父子类中,方法名、参数列表必须相同,返回值范围小于等于父类,抛出的异常范围小于等于父类,访问修饰符范围大于等于父类;如果父类方法访问修饰符为 private 则子类就不能重写该方法。
❷ java涓瀛愮被閲嶅啓缁ф圹镄勬柟娉旷殑瑙勫垯鏄浠涔堬纻
A銆侀吨鍐栾勫垯涔嬩竴锛歕x0dx0a 閲嶅啓鏂规硶涓嶈兘姣旇閲嶅啓鏂规硶闄愬埗链夋洿涓ユ牸镄勮块梾绾у埆銆俓x0dx0a锛堜絾鏄鍙浠ユ洿骞挎硾锛屾瘆濡傜埗绫绘柟娉曟槸鍖呰块梾𨱒冮檺锛屽瓙绫荤殑閲嶅啓鏂规硶鏄痯ublic璁块梾𨱒冮檺銆傦级 B銆侀吨鍐栾勫垯涔嬩簩锛歕x0dx0a 鍙傛暟鍒楄〃蹇呴’涓庤閲嶅啓鏂规硶镄勭浉钖屻俓x0dx0a閲嶅啓链変釜瀛鐢熺殑寮熷纻鍙閲嶈浇锛屼篃灏辨槸钖庨溃瑕佸嚭鍦虹殑銆傚傛灉瀛愮被鏂规硶镄勫弬鏁颁笌鐖剁被瀵瑰簲镄勬柟娉曚笉钖岋纴闾d箞灏辨槸浣犺ら敊浜轰简锛岄偅鏄閲嶈浇锛屼笉鏄閲嶅啓銆 x0dx0aC銆侀吨鍐栾勫垯涔嬩笁锛歕x0dx0a 杩斿洖绫诲瀷蹇呴’涓庤閲嶅啓鏂规硶镄勮繑锲炵被鍨嬬浉钖屻俓x0dx0aD銆侀吨鍐栾勫垯涔嫔洓锛歕x0dx0a 閲嶅啓鏂规硶涓嶈兘鎶涘嚭鏂扮殑寮傚父鎴栬呮瘆琚閲嶅啓鏂规硶澹版槑镄勬镆ュ纾甯告洿骞跨殑妫镆ュ纾甯搞备絾鏄鍙浠ユ姏鍑烘洿灏戯纴镟存湁闄愭垨钥呬笉鎶涘嚭寮傚父銆俓x0dx0aE銆侀吨鍐栾勫垯涔嬩簲锛歕x0dx0a 涓嶈兘閲嶅啓琚镙囱瘑涓篺inal镄勬柟娉曘俓x0dx0aF銆侀吨鍐栾勫垯涔嫔叚锛歕x0dx0a 濡傛灉涓涓鏂规硶涓嶈兘琚缁ф圹锛屽垯涓嶈兘閲嶅啓瀹冦
❸ java里的重写,重载,覆盖的区别
重写即覆盖,重载与覆盖的区别是:
1)方法覆盖要求参数签名必须一致,而方法重载要求参数签名必须不一致;
2)方法覆盖要求返回类型必须一致,而方法重载对此不作要求
3)方法覆盖只能用于子类覆盖父类的方法,而方法重载用于同一个类中所有的方法(包括从父类中继承过来的方法)
4)方法覆盖对方法的访问权限和抛出的异常有特殊的要求,而方法重载对此无要求
5)父类的一个方法只能被子类覆盖一次,而一个方法在所在的类中可以被重载多次
❹ 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的啊!应该可以调用啊!请牢记,多态只看父类引用的方法,而不看子类对象的方法!