Java笔记14:泛型初探
2016-01-15 21:36
489 查看
一、泛型简介
泛型是从Java SE 1.5开始出现的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。 Java语言引入泛型的好处是安全简单。
在Java SE 1.5之前,没有泛型的情况的下,通过对类型Object的引用来实现参数的“任意化”,“任意化”带来的缺点是要做显式的强制类型转换,而这种转换是要求开发者对实际参数类型可以预知的情况下进行的。对于强制类型转换错误的情况,编译器可能不提示错误,在运行的时候才出现异常,这是一个安全隐患。
泛型的好处是在编译的时候检查类型安全,并且所有的强制转换都是自动和隐式的,以提高代码的重用率。
二、代码实现
这里给出了两个例子实现同样的功能,一个使用了泛型,一个没有使用泛型,通过对比,可以很快学会泛型的应用,学会这两个例子基本上就学会了泛型70%的内容。
例1:使用了泛型
classGen<T> {
private T
obj;
public Gen(T
obj) {
this.obj
= obj;
}
public TgetObj() {
return
obj;
}
public
void setObj(T
obj) {
this.obj
= obj;
}
public
void printType() {
System.out.println("T的实际类型为:"
+ obj.getClass().getName());;
}
}
public
class GenDemo {
public
static
voidmain(String[]
args) {
Gen<Integer> intObj =
new Gen<Integer> (888);
intObj.printType();
int
i =
intObj.getObj();
System.out.println("value = "
+ i);
System.out.println("----------我是分割线----------");
Gen<String> strObj =
new Gen<String>("Hello Gen!");
strObj.printType();
String s =
strObj.getObj();
System.out.println("value
= " + s);
}
}
运行结果:
T的实际类型为:java.lang.Integer
value =888
----------我是分割线----------
T的实际类型为:java.lang.String
value =Hello Gen!
例2:不使用泛型
class Gen2 {
private Object
obj;
publicGen2(Object
obj) {
this.obj
= obj;
}
public ObjectgetObj() {
return
obj;
}
public
void setObj(Object
obj) {
this.obj
= obj;
}
public
void printType() {
System.out.println("T的实际类型为:"
+ obj.getClass().getName());
}
}
public
class GenDemo2 {
public
static
voidmain(String[]
args) {
Gen2 intObj =
new Gen2(new
Integer(666));
intObj.printType();
int
i =(Integer)intObj.getObj();
System.out.println("value = "
+ i);
System.out.println("----------我是分割线----------");
Gen2 strObj =
new Gen2("Hello Gen!");
strObj.printType();
String s =(String)strObj.getObj();
System.out.println("value = "
+ s);
}
}
运行结果:
T的实际类型为:java.lang.Integer
value =666
----------我是分割线----------
T的实际类型为:java.lang.String
value = Hello Gen!
一、泛型简介
泛型是从Java SE 1.5开始出现的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。 Java语言引入泛型的好处是安全简单。
在Java SE 1.5之前,没有泛型的情况的下,通过对类型Object的引用来实现参数的“任意化”,“任意化”带来的缺点是要做显式的强制类型转换,而这种转换是要求开发者对实际参数类型可以预知的情况下进行的。对于强制类型转换错误的情况,编译器可能不提示错误,在运行的时候才出现异常,这是一个安全隐患。
泛型的好处是在编译的时候检查类型安全,并且所有的强制转换都是自动和隐式的,以提高代码的重用率。
二、代码实现
这里给出了两个例子实现同样的功能,一个使用了泛型,一个没有使用泛型,通过对比,可以很快学会泛型的应用,学会这两个例子基本上就学会了泛型70%的内容。
例1:使用了泛型
classGen<T> {
private T
obj;
public Gen(T
obj) {
this.obj
= obj;
}
public TgetObj() {
return
obj;
}
public
void setObj(T
obj) {
this.obj
= obj;
}
public
void printType() {
System.out.println("T的实际类型为:"
+ obj.getClass().getName());;
}
}
public
class GenDemo {
public
static
voidmain(String[]
args) {
Gen<Integer> intObj =
new Gen<Integer> (888);
intObj.printType();
int
i =
intObj.getObj();
System.out.println("value = "
+ i);
System.out.println("----------我是分割线----------");
Gen<String> strObj =
new Gen<String>("Hello Gen!");
strObj.printType();
String s =
strObj.getObj();
System.out.println("value
= " + s);
}
}
运行结果:
T的实际类型为:java.lang.Integer
value =888
----------我是分割线----------
T的实际类型为:java.lang.String
value =Hello Gen!
例2:不使用泛型
class Gen2 {
private Object
obj;
publicGen2(Object
obj) {
this.obj
= obj;
}
public ObjectgetObj() {
return
obj;
}
public
void setObj(Object
obj) {
this.obj
= obj;
}
public
void printType() {
System.out.println("T的实际类型为:"
+ obj.getClass().getName());
}
}
public
class GenDemo2 {
public
static
voidmain(String[]
args) {
Gen2 intObj =
new Gen2(new
Integer(666));
intObj.printType();
int
i =(Integer)intObj.getObj();
System.out.println("value = "
+ i);
System.out.println("----------我是分割线----------");
Gen2 strObj =
new Gen2("Hello Gen!");
strObj.printType();
String s =(String)strObj.getObj();
System.out.println("value = "
+ s);
}
}
运行结果:
T的实际类型为:java.lang.Integer
value =666
----------我是分割线----------
T的实际类型为:java.lang.String
value = Hello Gen!
相关文章推荐
- Spring的事件处理
- Java IO流类继承关系及使用说明
- Java语言概述
- spring-依赖注入
- IO_总结JAVA168
- eclipse中装了MyEclipse插件之后不能创建web project
- 如何利用Java获取系统的信息(CPU、内存、各盘符使用情况)
- Java API 与HBase交互实例
- Java笔记10:Struts2简单Demo
- weka+eclipse算法二次开发(1)
- Java字符串的一些理解
- Eclipse中添加文档注释快捷键
- hdu 折线切割平面 (java)
- struts2--值栈以及OGNL
- Struts中ActionContext和ServletActionContext的比较
- 深入分析JavaWeb Item54 -- Spring中的AOP面向切面编程2
- hbase异常:java.io.IOException: Unable to determine ZooKeeper ensemble
- 蓝桥杯-基础练习-十进制转十六进制
- HBase的javaAPI的增删改查的基本操作实现
- java中的URLConnection