重載方法呼叫:優先考慮實參數類型
Java 的方法重載機制會根據聲明的參數類型選擇最合適的實現。然而,一個常見的誤解是它在重載解析期間也會考慮實際類型。
挑戰
考慮以下程式碼片段:
interface Callee { public void foo(Object o); public void foo(String s); public void foo(Integer i); } class CalleeImpl implements Callee { public void foo(Object o) { logger.debug("foo(Object o)"); } public void foo(String s) { logger.debug("foo(\"" + s + "\")"); } public void foo(Integer i) { logger.debug("foo(" + i + ")"); } } Callee callee = new CalleeImpl(); Object i = new Integer(12); Object s = "foobar"; Object o = new Object(); callee.foo(i); callee.foo(s); callee.foo(o);
執行後,此程式碼意外地列印了 3 次「foo(Object o)”,而不是根據真實參數選擇不同的實現
根本原因
在Java 中,方法調用會為調用該方法的對象動態分派,但不會為參數類型分派。 Java 語言規範明確指出「參數的編譯時類型」決定了所選方法簽章。
因此,參數宣告會覆寫參數分配期間發生的任何潛在型別轉換或提升。因此,所提供程式碼中的所有三個呼叫都解析為「foo(Object o)」方法,因為 Object 是所有三個參數的宣告類型。
解
要解決此問題並在重載解析中優先考慮真實參數類型,請考慮以下策略:
以上是Java 方法重載如何處理實際參數類型與宣告類型?的詳細內容。更多資訊請關注PHP中文網其他相關文章!