java 函數(shù)的重載和重寫實例代碼
在java中多態(tài)分為兩種編譯時多態(tài)(重載)和運行時多態(tài)(重寫),編譯時多態(tài)又叫前綁定,運行時多態(tài)又叫后綁定。
下面用一個例子說明:
public class OverloadAndOverwrite {
public static void main(String[] args) {
A a1 = new A();
A a2 = new B();
B b = new B();
C c = new C();
D d = new D();
System.out.print("a1.print(a1): ");
a1.print(a1);//輸出A and A
System.out.print("a1.print(b): ");
a1.print(b);//輸出A and A:原因是因為A中不存在參數(shù)為B的方法,因此會調(diào)用參數(shù)為A的方法,因為B是繼承自A的
System.out.print("a1.print(c): ");
a1.print(c);//輸出A and A:原因是因為A中不存在參數(shù)為C的方法,因此會調(diào)用參數(shù)為A的方法,因為C是繼承自B的,B是繼承自A的
System.out.print("a1.print(d): ");
a1.print(d);//輸出A and D:原因是因為A中存在參數(shù)為D的方法,因此會調(diào)用參數(shù)為D的方法
System.out.print("a2.print(b): ");
a2.print(b);//輸出B and A:原因在于首先入口是A,首先查看A中是否有參數(shù)為B的print方法,發(fā)現(xiàn)沒有那就尋找有沒有參數(shù)為A的方法,因為B是繼承自A的,發(fā)現(xiàn)存在這樣的方法,那么再次查看B中有沒有重寫這個方法,發(fā)現(xiàn)有重新,直接調(diào)用B中這個重寫的方法
System.out.print("a2.print(c): ");
a2.print(c);//輸出B and A:原因在于首先入口是A,首先查看A中是否有參數(shù)為C的print方法,發(fā)現(xiàn)沒有那就尋找有沒有參數(shù)為B的方法,因為C是繼承自B的,發(fā)現(xiàn)也不存在這樣的方法,那就尋找存在參數(shù)為A的print方法,因為B繼承自A,發(fā)現(xiàn)存在這樣的方法,那么再次查看B中有沒有重寫這個方法,發(fā)現(xiàn)有重新,直接調(diào)用B中這個重寫的方法
System.out.print("a2.print(d): ");
a2.print(d);//輸出 A and D:原因在于入口是A,查看A中存在參數(shù)為D的方法,再次查看B中沒有重寫這個方法,因此輸出A中這個方法的結(jié)果即可;
System.out.print("a2.print(a2): ");
a2.print(a2);//輸出B and A;原因在于a2的類型是A,因此會調(diào)用A里面參數(shù)為A的print方法,但是a2右邊new的是B,所以因為B中有參數(shù)為A的方法,因此采用的是B里面的這個方法
System.out.print("b.print(b): ");
b.print(b);//輸出B and B;原因:入口是B,因此查看B中存不存在參數(shù)為B的print函數(shù),存在則直接輸出;
System.out.print("b.print(c): ");
b.print(c);//輸出B and B;原因:入口是B,因此查看B中存不存在參數(shù)為C的print函數(shù),發(fā)現(xiàn)不存在,則查看存不存在參數(shù)為B的print函數(shù),發(fā)現(xiàn)存在,并且C中并沒有重寫該方法,則直接輸出;有一點需要注意的是還需要查看一下A中是否存在參數(shù)為C的print方法,因為B繼承自A,有的話會及成果來這個方法,這樣的話輸出的結(jié)果將變?yōu)锳 and C
System.out.print("b.print(d): ");
b.print(d);//輸出A and D;原因:入口是B,雖然B中不存在參數(shù)為D的print函數(shù),但是B繼承自A,A中是存在參數(shù)為D的print函數(shù)的,因此輸出的是A中參數(shù)為D的結(jié)果;
}
}
class A
{
public void print(A a)
{
System.out.println("A and A");
}
public void print(D d)
{
System.out.println("A and D");
}
// public void print(C c)
// {
// System.out.println("A and C");
// }
}
class B extends A
{
public void print(B b)
{
System.out.println("B and B");
}
public void print(A a)
{
System.out.println("B and A");
}
}
class C extends B{}
class D extends C{}
在此需要說明的是:
對于 A a2 = new B( );
如果單獨打印出a2的話,打印結(jié)果是B@(hash碼),而不是A@(hash碼),但這并不能說明a2的類型是B類型的,因為當我們在上面程序中調(diào)用a2.print(a2);的時候輸出的結(jié)果是B and A而不是A and A(如果假設(shè)a2是B類型的話,就應(yīng)該調(diào)用A類中參數(shù)為B的print方法,因為不存在這樣的方法,那么退而求其次調(diào)用參數(shù)為A的方法就應(yīng)該輸出A and A了,因為B是A的子類)。
以上就是對重寫和重載的實例代碼分析,希望對Java學習的同學有幫助。
相關(guān)文章
POST方法給@RequestBody傳參數(shù)失敗的解決及原因分析
這篇文章主要介紹了POST方法給@RequestBody傳參數(shù)失敗的解決及原因分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10
關(guān)于@ComponentScan?TypeFilter自定義指定掃描bean的規(guī)則
這篇文章主要介紹了關(guān)于@ComponentScan?TypeFilter自定義指定掃描bean的規(guī)則,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09
java解析dbf之通過javadbf包生成和讀取dbf文件
這篇文章主要介紹了java通過javadbf讀取和生成DBF文件的方法,大家參考使用吧2014-01-01
Springboot詳細講解RocketMQ實現(xiàn)順序消息的發(fā)送與消費流程
RocketMQ作為一款純java、分布式、隊列模型的開源消息中間件,支持事務(wù)消息、順序消息、批量消息、定時消息、消息回溯等,本篇我們了解如何實現(xiàn)順序消息的發(fā)送與消費2022-06-06

