對泛型的理解

    沒有使用泛型時,只要是對象,不管是什麼類型的對象,都可以存儲進同一個集合中。使用泛型集合,可以將一個集合中的元素限定爲一個特定類型,集合中只能存儲同一個類型的對象,這樣更安全;並且當從集合獲取一個對象時,編譯器也可以知道這個對象的類型,不需要對對象進行強制類型轉換,這樣更方便。

泛型就是把原來的類名進行了延長

   一下是一個簡單的例子:

package javatribe.fts.generic;

import java.util.ArrayList;

public class GenericTest {

	/**
	 * @param args
	 */
	public static void main(String[] args) throws Exception{
		// TODO Auto-generated method stub
         ArrayList collection=new ArrayList();
         collection.add(1);
         collection.add(1L);
         collection.add("aaaaa");
         //int i=(Integer)collection.get(1);
         
         ArrayList<String> collection1=new ArrayList<String>();
         //collection1.add(1);
         //collection1.add(1L);
         collection1.add("aaaaa");
         String str=collection1.get(0);
         System.out.println(str);
         
         ArrayList<Integer> collection2=new ArrayList<Integer>();
         collection2.add(1);
         System.out.println(collection1.getClass()==collection2.getClass());
	
         collection2.getClass().getMethod("add", Object.class).invoke(collection2, "abc");
         System.out.println(collection2.get(1));
	
	}

}
輸出結果爲:

aaaaa
true
abc
    看如下代碼,定義一個類型爲整型集合,然後add一個整數進去,要是add一個字符串進去會提示錯誤。但是用反射機制傳入一個字符串反而可以的。因爲反射是在運行期起作用的,二泛型主要是給編譯器看的
ArrayList<Integer> collection2=new ArrayList<Integer>();
         collection2.add(1);
         System.out.println(collection1.getClass()==collection2.getClass());
	
         collection2.getClass().getMethod("add", Object.class).invoke(collection2, "abc");
         System.out.println(collection2.get(1));

   所以由以上例子輸出結果可以分析得到泛型是提供給javac編譯器使用的,可以限定集合中的輸入類型,讓編譯器擋住源程序中的非法輸入,編譯器編譯帶類型說明的集合時會去除掉“類型”信息,使程序運行效率不受影響,對於參數化的泛型類型,getClass()方法的返回值和原始類型完全一樣。由於編譯生成的字節碼會去掉泛型的類型信息,只要能跳過編譯器,就可以往某個泛型集合中加入其它類型的數據,例如,用反射得到集合,再調用其add方法即可。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章