java在1.5版本中增加了泛型,在没有泛型之前,从集合中读取每一个对象都需要进行强转,如果一不小心插入了类型错误的对象,在运行时就会报错,给日常开发带来了很多不必要的麻烦,比如以下代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
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);
}
}
}
|
1
2
|
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 )
|
经过运行,立马脾气来了,小样,来本事啦!
list和list< object>有什么区别,不严格的说,前者逃避了泛型检查,后者告诉编译器,持有一个object类型的对象,属于编译器的一种优化,在编译的时候不通过来增加类型的安全性。如果上述代码使用的是泛型,便可以避免这类事故的发生,在java的编程思想中,一直在提倡“出错之后尽快发现”,那么编译时发现报错肯定优先于运行时的报错,此处做了一个简单的修改:
此处仅仅是把list改成了list< string>去检查add时候值的类型,如果add时候值的类型是非法的,编译时便会报错。
对于创建泛型对象,几乎每个开发者都会使用过,比如最初学的class.forname()返回的对象就是class< t>,对于泛型方法,会有部分开发者显得有点摸不着头脑,好吧,啥废话都不说了,就是干,先代码再上图:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
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以外,常见的还有以下几种:
- e - element (在集合中使用,因为集合中存放的是元素)
- k - key(键)
- v - value(值)
- n - number(数值类型)
- ? - 表示不确定的java类型
日常开发中什么时候用到泛型?那就多了,比如解析json的时候,正常情况下,后台返回的json基本格式都是相同的,但是里面字段各有不同,通过泛型传入不同的model,大大的提高了代码的可重用性和可维护性,为了以后的开发省去太多不必要的麻烦。
以上就是java泛型的使用方法总结,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/pangpang123654/article/details/52593269