本文實(shí)例總結(jié)了Java中泛型的用法。分享給大家供大家參考。具體如下:
1 基本使用
1
2
3
4
|
public interface List<E> { void add(E); Iterator<E> iterator(); } |
2 泛型與子類
Child是Parent的子類,List<Child>卻不是List<Parent>的子類。
因此:List<Object> list = new ArrayList<String>()是錯(cuò)誤的。
如果上面是正確的,那么:
1
2
3
4
|
List<String> ls = new ArrayList<String>(); //1 List<Object> lo = ls; //2 lo.add( new Object()); // 3 String s = ls.get( 0 ); // 4,將object轉(zhuǎn)換為string將失敗。 |
3 wildcards
因?yàn)?的原因,下面的實(shí)現(xiàn)用于統(tǒng)配集合的輸出是不行的
1
2
3
4
5
|
void printCollection(Collection<Object> c) { for (Object o: c) { // do something } } |
因此,需要通配符?:
1
2
3
4
5
|
void printCollection(Collection<?> c) { for (Object o: c) { // 1 // do something } } // ok |
此處的?表示類型未知,但是任何對(duì)象均是Object,因此上例的1是正確的。但下例卻是錯(cuò)誤的:
1
2
3
|
void add(Collection<? extends MyClass> c) { c.add( new MyClass()); // wrong } // ok |
原因也很明確,? extends MyClass說明類型是MyClass的子類,但是卻并不知道具體類型
4. 泛型方法
上例可以實(shí)現(xiàn)為:
1
2
3
|
<T> add(Collection<T> c, T t) { c.add(t); } |
編譯器在保證語義的前提,會(huì)幫忙做類型的轉(zhuǎn)換工作。
5. 泛型運(yùn)行時(shí)的對(duì)比
1
2
3
|
List<String> l1 = new ArrayList<String>(); List<Integer> l2 = new ArrayList<Integer>(); System.out.println(l1.getClass() == l2.getClass()); // true |
因?yàn)榉盒皖愡\(yùn)行時(shí)時(shí)一樣的。
6 泛型數(shù)組(可能導(dǎo)致類型不安全)
如果可以的話,可能導(dǎo)致類型不安全。如:
1
2
3
4
5
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 |
希望本文所述對(duì)大家的java程序設(shè)計(jì)有所幫助。