java在1.5版本中增加了泛型,在沒有泛型之前,從集合中讀取每個(gè)對象都需要進(jìn)行強(qiáng)轉(zhuǎn),如果1不謹(jǐn)慎插入了類型毛病的對象,在運(yùn)行時(shí)就會(huì)報(bào)錯(cuò),給平常開發(fā)帶來了很多沒必要要的麻煩,比如以下代碼:
public class TestGeneric
{
public static void main(String[] args) {
List list = new ArrayList();
list.add(" name:");
list.add(" zero,");
list.add(" age:");
list.add(24);
list.add(false);
for (Object object : list)
{
String test = (String) object;
System.out.print(test);
}
}
}
name:zero,age:Exception in thread "main" java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
at com.zm.zero.test.TestGeneric.main(TestGeneric.java:18)
經(jīng)過運(yùn)行,立馬脾氣來了,小樣,來本事啦!
List和List< Object>有甚么區(qū)分,不嚴(yán)格的說,前者回避了泛型檢查,后者告知編譯器,持有1個(gè)Object類型的對象,屬于編譯器的1種優(yōu)化,在編譯的時(shí)候不通過來增加類型的安全性。如果上述代碼使用的是泛型,即可以免這類事故的產(chǎn)生,在Java的編程思想中,1直在提倡“出錯(cuò)以后盡快發(fā)現(xiàn)”,那末編譯時(shí)發(fā)現(xiàn)報(bào)錯(cuò)肯定優(yōu)先于運(yùn)行時(shí)的報(bào)錯(cuò),此處做了1個(gè)簡單的修改:
此處僅僅是把List改成了List< String>去檢查add時(shí)候值的類型,如果add時(shí)候值的類型是非法的,編譯時(shí)便會(huì)報(bào)錯(cuò)。
對創(chuàng)建泛型對象,幾近每一個(gè)開發(fā)者都會(huì)使用過,比如最初學(xué)的Class.forName()返回的對象就是Class< T>,對泛型方法,會(huì)有部份開發(fā)者顯得有點(diǎn)摸不著頭腦,好吧,啥空話都不說了,就是干,先代碼再上圖:
public class JsonToModel
{
/**
*
* @param msg
* @param t
* model類
* @return
*/
public static <T extends BaseModel<T>> T getJsonToModel(Message msg, Class<T> t) {
// TODO Auto-generated method stub
try
{
JsonObject jsonObject = new JsonParser().parse(msg.obj.toString())
.getAsJsonObject().getAsJsonObject("info");
return GsonHelper.toType(jsonObject.toString(), t);
} catch (Exception e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
}
除T之外,常見的還有以下幾種:
平常開發(fā)中甚么時(shí)候用到泛型?那就多了,比如解析json的時(shí)候,正常情況下,后臺(tái)返回的json基本格式都是相同的,但是里面字段各有不同,通過泛型傳入不同的model,大大的提高了代碼的可重用性和可保護(hù)性,為了以后的開發(fā)省去太多沒必要要的麻煩。