Java中泛型的用法總結
本文實例總結了Java中泛型的用法。分享給大家供大家參考。具體如下:
1 基本使用
public interface List<E> {
void add(E);
Iterator<E> iterator();
}
2 泛型與子類
Child是Parent的子類,List<Child>卻不是List<Parent>的子類。
因此:List<Object> list = new ArrayList<String>()是錯誤的。
如果上面是正確的,那么:
List<String> ls = new ArrayList<String>(); //1 List<Object> lo = ls; //2 lo.add(new Object()); // 3 String s = ls.get(0); // 4,將object轉換為string將失敗。
3 wildcards
因為2的原因,下面的實現用于統(tǒng)配集合的輸出是不行的
void printCollection(Collection<Object> c) {
for (Object o: c) {
// do something
}
}
因此,需要通配符?:
void printCollection(Collection<?> c) {
for (Object o: c) { // 1
// do something
}
} // ok
此處的?表示類型未知,但是任何對象均是Object,因此上例的1是正確的。但下例卻是錯誤的:
void add(Collection<? extends MyClass> c) {
c.add(new MyClass()); // wrong
} // ok
原因也很明確,? extends MyClass說明類型是MyClass的子類,但是卻并不知道具體類型
4. 泛型方法
上例可以實現為:
<T> add(Collection<T> c, T t) {
c.add(t);
}
編譯器在保證語義的前提,會幫忙做類型的轉換工作。
5. 泛型運行時的對比
List<String> l1 = new ArrayList<String>(); List<Integer> l2 = new ArrayList<Integer>(); System.out.println(l1.getClass() == l2.getClass()); // true
因為泛型類運行時時一樣的。
6 泛型數組(可能導致類型不安全)
如果可以的話,可能導致類型不安全。如:
Object o = lsa; Object []oa = (Object[])o; List<Integer> li = new ArrayList<Integer>(); li.add(new Integer(3)); oa[1] = li; String s = lsa[1].get(0); // runtime error
希望本文所述對大家的java程序設計有所幫助。
相關文章
如何解決SpringBoot2.6及之后版本取消了循環(huán)依賴的支持問題
循環(huán)依賴指的是兩個或者多個bean之間相互依賴,形成一個閉環(huán),SpringBoot從2.6.0開始默認不允許出現Bean循環(huán)引用,解決方案包括在全局配置文件設置允許循環(huán)引用存在、在SpringApplicationBuilder添加設置允許循環(huán)引用、構造器注入2024-10-10
如何使用IntelliJ IDEA中的Live Templates自定義代碼模板
在IntelliJ IDEA中,通過使用LiveTemplates功能,可以實現快速編碼和自定義代碼模板,例如,輸入“main”可以自動補全主函數結構,“sout”可以補全輸出語句,用戶可以通過設置中的LiveTemplates選項查看和定義快捷模板,支持使用分組管理和參數化模板內容,適應復雜的編碼需求2024-11-11
java.util.Collections類—emptyList()方法的使用
這篇文章主要介紹了java.util.Collections類—emptyList()方法的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11
idea創(chuàng)建springboot項目,java版本只能選擇17和21的解決方案
這篇文章主要介紹了idea創(chuàng)建springboot項目,java版本只能選擇17和21的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-04-04

