您好,登錄后才能下訂單哦!
本篇內容介紹了“Java擦除和轉換舉例分析”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
一 點睛
在嚴格的泛型代碼里,帶泛型聲明的類總應該帶著類型參數。但為了與老的Java代碼保持一致,也允許在使用帶泛型聲明的類時不指定類型參數。如果沒有為這個泛型類指定類型參數,則該類型參數被稱作一個raw type(原始類型),默認是該聲明該參數時指定的第一個上限類型。
當把一個具有泛型信息的對象賦給另一個沒有泛型信息的變量時,則所有在尖括號之間的類型信息都被扔掉了。比如說一個List<String>
類型被轉換為List,則該List對集合元素的類型檢查變成了成類型變量的上限(即Object),這種情況被為擦除。
二 實戰——擦除
class Apple<T extends Number>{ T size; public Apple() { } public Apple(T size) { this.size = size; } public void setSize(T size) { this.size = size; } public T getSize() { return this.size; }}public class ErasureTest{ public static void main(String[] args) { Apple<Integer> a = new Apple<>(6); // ① // a的getSize方法返回Integer對象 Integer as = a.getSize(); // 把a對象賦給Apple變量,丟失尖括號里的類型信息 Apple b = a; // ② // b只知道size的類型是Number Number size1 = b.getSize(); // 下面代碼引起編譯錯誤 //Integer size2 = b.getSize(); // ③ }}
三 實戰——擦除與轉換
import java.util.*;public class ErasureTest2{ public static void main(String[] args) { List<Integer> li = new ArrayList<>(); li.add(6); li.add(9); List list = li; // 下面代碼引起“未經檢查的轉換”的警告,編譯、運行時完全正常 List<String> ls = list; // ① // 但只要訪問ls里的元素,如下面代碼將引起運行時異常。 //System.out.println(ls.get(0)); }}
“Java擦除和轉換舉例分析”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。