透過實例呼叫靜態方法的奇怪情況
儘管人們普遍了解Java 的特殊行為,但問題仍然存在:為什麼要呼叫實例的靜態方法不會被編譯器視為錯誤?
編譯器設計不幸
Java 設計者無意中將這種異常引入到語言的設計中。嘗試糾正該問題會帶來相容性挑戰,使其成為一個持久的缺陷。
誤導性代碼
雖然該行為在技術上並不錯誤,但它會導致高度誤導代碼。使用點運算子呼叫方法意味著使用實例的值。當方法是靜態的時,就違反了這個期望。
不一致的處理
Java 對靜態方法呼叫的處理不一致。雖然它不允許透過未初始化的實例變數呼叫靜態方法,但它會授予初始化實例的權限,即使執行時間值無關。
繼承注意事項
與聲明相反,繼承不適用於靜態方法。它們不是多態的,如以下程式碼所示:
class Base { static void foo() { System.out.println("Base.foo()"); } } class Derived extends Base { static void foo() { System.out.println("Derived.foo()"); } } public class Test { public static void main(String[] args) { Base b = new Derived(); b.foo(); // Prints "Base.foo()" } }
靜態方法呼叫不受實例的執行時間值的影響,揭示了多態性的缺乏,並進一步突出了此類呼叫的誤導性。
以上是為什麼 Java 不將透過實例呼叫靜態方法視為錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!