JavaSE-面向對象(方法重寫)
方法重寫與之前的方法重載不同
回顧一下方法重載,相同的方法名不同參數(shù)類型和參數(shù)數(shù)量以及參數(shù)順序
package Demo1;
import java.util.Arrays;
public class Demo011 {
public static void main(String[] args) {
Demo011 D11=new Demo011();
D11.demo(12,232,43,3); //4個實際參數(shù),則調用第三個demo方法
}
public void demo(int a,int b){
System.out.println(a+b);
}
public void demo(int a,int b,int c){
System.out.println(a+b+c);
}
public void demo(int...ints){
System.out.println(Arrays.toString(ints));
}
}
方法重寫
重寫都是方法的重寫與屬性無關
package Demo1;
public class Demo012 {
public static void main(String[] args) {
B b =new B();
b.demo();
}
}
class A{
public static void demo(){
System.out.println("Ademo");
}
}
class B extends A{
public static void demo(){
System.out.println("Bdemo");
}
}
執(zhí)行結果:
Bdemo
父類的引用指向子類進行引用
public static void main(String[] args) {
//方法的調用只和數(shù)據(jù)類型有關
B b =new B(); //調用的是B類的靜態(tài)方法
b.demo();
//父類的引用指向子類
A a = new A(); //調用的是A類的靜態(tài)方法
a.demo();
}
執(zhí)行結果:
Bdemo
Ademo
使用快捷鍵Alt+insert快速生成重寫方法


Override重寫方法
class A{
public void demo(){
System.out.println("Ademo");
}
}
class B extends A{
@Override //注解,有功能的注釋
public void demo() {
super.demo(); //默認調用父類的demo()方法
}
}
使用Override重寫默認是調用父類的方法,我們可以在重寫方法中調用自己的方法
class A{
public void demo(){
System.out.println("Ademo");
}
}
class B extends A{
@Override
public void demo() {
//super.demo(); 默認調用父類的demo()方法輸出Ademo
System.out.println("Bdemo");
}
}
重寫之后執(zhí)行結果:
Bdemo
Bdemo
子類重寫父類的demo()方法之后輸出為demoB,但是并不是子類重寫之后將父類的方法修改了,子類在進行調用的時候調用的是重寫后父類的方法
package Demo3;
public class demo005 {
public static void main(String[] args) {
DemoB DB =new DemoB();
DB.demo(); //調用子類的demo
DemoA DA=new DemoA(); //調用父類的demo
DA.demo();
}
}
class DemoA{
public void demo(){
System.out.println("demoA");
}
}
class DemoB extends DemoA{ //繼承
@Override
public void demo(){
System.out.println("demoB");
}
}
執(zhí)行結果:
demoB
demoA
但是我可以完全不繼承父類也能輸出demoB,demoA
package Demo3;
public class demo005 {
public static void main(String[] args) {
DemoB DB =new DemoB();
DB.demo();
DemoA DA=new DemoA();
DA.demo();
}
}
class DemoA{
public void demo(){
System.out.println("demoA");
}
}
class DemoB{ //A與B沒有繼承關系
public void demo(){
System.out.println("demoB");
}
}
執(zhí)行結果:
demoB
demoA
兩種方式有什么區(qū)別呢?
- 子類繼承父類重寫方法,是通過子類調用父類的方法進行重寫的,子類執(zhí)行結果也是重寫后的方法,但并不是子類把父類的方法修改了
- 方式二是在兩個不同類下創(chuàng)建demo()方法,通過對象進行調用。
父類方法若添加static修飾符則重寫失敗提示錯誤
進行方法重寫時靜態(tài)方法和非靜態(tài)方法的區(qū)別很大,如果是加了static靜態(tài)方法,調用結果之和左邊定義的類有關。方法重寫與非靜態(tài)方法有關

私有方法無法進行方法重寫,重寫的關鍵詞只能是public不能是private私有的

重寫小結:
- 方法重寫需要有繼承關系,子類重寫父類的方法
- 子類方法與父類的方法方法名和修飾符必須相同
- 以及方法的參數(shù)列表必須相同,不相同則為方法重載
- 修飾符范圍可以擴大但是不能縮小,private(小)–>proteated–>default–>public(大)
- 重寫可能會拋出異常,異常范圍可以被縮小但不能擴大
為什么需要重寫?
- 父類的功能子類不一定需要或者不一定滿足,父類的東西太多了子類可能只需要一點
快捷鍵Alt+insert
快速創(chuàng)建Override
總結
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內(nèi)容!
相關文章
SpringBoot集成Redis—使用RedisRepositories詳解
這篇文章主要介紹了SpringBoot集成Redis—使用RedisRepositories詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
SpringBoot集成Graphql Query實戰(zhàn)示例
這篇文章主要為大家介紹了SpringBoot集成Graphql Query實戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09
Spring?Cloud中Sentinel的兩種限流模式介紹
如何使用Sentinel做流量控制呢?這篇文章就來為大家詳細介紹了Spring?Cloud中Sentinel的兩種限流模式,感興趣的小伙伴可以跟隨小編一起學習一下2023-05-05
java序列化對象根據(jù)不同配置動態(tài)改變屬性名的方法
本文主要介紹了java序列化對象根據(jù)不同配置動態(tài)改變屬性名的方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05

