使用泛型方法了解原始類型的行為
使用Java 的泛型時,了解使用原始類型的含義至關重要及其對通用方法的影響。讓我們深入研究一個特定的程式碼範例,並探討原始類型如何影響方法解析。
考慮以下程式碼片段,其中建立字串的 ArrayList 並將其轉換為陣列:
ArrayList<String> a = new ArrayList<String>(); String[] s = a.toArray(new String[0]);
正如預期的那樣,此程式碼在 Java 1.6 和 1.7 中成功編譯。但是,如果ArrayList 引用被宣告為原始類型,則編譯期間會發生錯誤:
ArrayList a = new ArrayList(); String[] s = a.toArray(new String[0]); // Error: Argument required String[] found Object[]
在這種情況下,編譯器將泛型方法toArray(myArray) 解釋為傳回Object[],儘管接收到String[] 作為其參數。這種行為是非常出乎意料的,因為方法簽名明確指定了類型參數
要理解這一點,讓我們考慮 Java 語言規格 (JLS) 第 4.8 節。它指出「未從其超類別或超介面繼承的原始類型C 的實例方法M 的類型是與C 對應的泛型聲明中其類型的擦除相對應的原始類型。」
本質上,當使用原始類型時,編譯器基本上會丟棄所有類型信息,只留下類別的原始表示形式。這意味著,在我們的範例中,toArray 方法實際上成為具有 Object[] 傳回類型的非泛型方法,即使它最初被定義為泛型方法。
原始類型中通用性的喪失具有重要的含義:
通常建議避免使用原始類型,而是依靠泛型來實現類型安全性和靈活性。但是,了解原始類型的行為可以幫助您解決問題並在特定場景中做出明智的決策。
以上是為什麼將原始型別與泛型方法一起使用會導致意外行為?的詳細內容。更多資訊請關注PHP中文網其他相關文章!