您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關JAVA中如何調用LIST接口的REMOVE重載方法的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
測試類設計
測試類一
public class Text { public void remove(int index){ System.out.println("調用傳參為int的remove方法"); } public void remove(Integer object){ System.out.println("調用傳參為Integer的remove方法"); } public void remove(Object object){ System.out.println("調用傳參為Object的remove方法"); } }
測試類二
public class Text { public void remove(Integer object){ System.out.println("調用傳參為Integer的remove方法"); } public void remove(Object object){ System.out.println("調用傳參為Object的remove方法"); } }
測試類三
public class Text { public void remove(Object object){ System.out.println("調用傳參為Object的remove方法"); } }
結果
三個測試類分別傳入int,Integer,Object型變量,觀察效果。
測試類一
傳入類型為int:調用傳參為int的remove方法
傳入類型為Integer:調用傳參為Integer的remove方法
傳入類型為Object:調用傳參為Object的remove方法
測試類二
傳入類型為int:調用傳參為Integer的remove方法
傳入類型為Integer:調用傳參為Integer的remove方法
傳入類型為Object:調用傳參為Object的remove方法
測試類三
傳入類型為int:調用傳參為Object的remove方法
傳入類型為Integer:調用傳參為Object的remove方法
傳入類型為Object:調用傳參為Object的remove方法
從輸出結果可以看出,當方法的傳參的類層級逐漸變高時,層級較低的傳參會進行向上轉型適應傳參的需要。
原因分析
下面我們先反編譯各測試類的源碼,結果如下
測試類一
invokevirtual #11 // Method remove:(I)V
invokevirtual #15 // Method remove:(Ljava/lang/Integer;)V
invokevirtual #18 // Method remove:(Ljava/lang/Object;)V
測試類二
invokevirtual #11 // Method remove:(Ljava/lang/Integer;)V
invokevirtual #11 // Method remove:(Ljava/lang/Integer;)V
invokevirtual #17 // Method remove:(Ljava/lang/Object;)V
測試類三
invokevirtual #10 // Method remove:(Ljava/lang/Object;)V
invokevirtual #10 // Method remove:(Ljava/lang/Object;)V
invokevirtual #10 // Method remove:(Ljava/lang/Object;)V
可以看出,反編譯代碼中都是調用實例方法的命令,所以結果中自動"向上轉型"其實是jvm的功勞。jvm通過在編譯時確定調用的傳參類型,靜態分派到具體方法的。
所以在前言中的困惑已經解除了,就是由于jvm中靜態分派的實現,調用次序是int->Integer->Object。
感謝各位的閱讀!關于“JAVA中如何調用LIST接口的REMOVE重載方法”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。