菜鸟学Java(二十二)——又一次认识泛型

菜鸟学Java(二十二)——又一次认识泛型

泛型是Java SE 1.5的新特性,泛型的本质是參数化类型,也就是说所操作的数据类型被指定为一个參数。这样的參数类型能够用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。

Java语言引入泛型的优点是安全简单。


规则和限制

1、泛型的类型參数仅仅能是类类型(包含自己定义类),不能是简单类型。
2、同一种泛型能够相应多个版本号(由于參数类型是不确定的),不同版本号的泛型类实例是不兼容的。
3、泛型的类型參数能够有多个。
4、泛型的參数类型能够使用extends语句,比如<T extends superclass>。习惯上称为“有界类型”。
5、泛型的參数类型还能够是通配符类型。比如Class<?> classType = Class.forName("java.lang.String")。


限制泛型
我们通常是这样定义泛型的:class Generics<T>。实际上这里的限定类型相当于Object,这和“Object泛型”实质是一样的。什么是限制比方我们要限制T为集合接口类型。仅仅须要这么做:class Generics<T extends Collection>。这样类中的泛型T仅仅能是Collection接口的实现类。传入非Collection接口编译会出错。

注意:<T extends Collection>这里的限定使用keywordextends,后面能够是类也能够是接口。但这里的extends已经不是继承的含义了,应该理解为T类型是实现Collection接口的类型,或者T是继承了XX类的类型。


public class CollectionGen<T extends Collection> {
	private T t;
	
	public CollectionGen(T t) {
		this.t = t;
	}
		
	public T getT() {
		return t;
	}

	public void setT(T t) {
		this.t = t;
	}


	public static void main(String args[]) {
		CollectionGen<ArrayList> genList = null;
		genList = new CollectionGen<ArrayList>(new ArrayList());
		
		//下面代码不能通过编译
//		CollectionGen<Collection> genCollention = null;
//		genCollention=new CollectionGen<ArrayList>(new ArrayList());
		System.out.println("能够编译通过并执行!");
	}
}

上面的代码是能够编译通过并成功执行的。可是打开凝视掉的两行就出错了,由于<T extends Collection>这么定义类型的时候,就限定了构造此类实例的时候T是确定的一个类型,这个类型实现了Collection接口。简单一句话就是:上面这样的方式,定义跟实例化的类型必须全然一致。


通配符泛型
为了解决类型被限制死了不能动态依据实例来确定的缺点,引入了“通配符泛型”,针对上面的样例,使用通配泛型格式为<? extends Collection>。“?”代表未知类型,这个类型是实现Collection接口。那么上面实现的方式能够写为:

	public static void main(String args[]) {
		Generics<ArrayList> genList = null;
		genList = new Generics<ArrayList>(new ArrayList());
		
		//下面代码能够通过编译
		Generics<?

extends Collection> genCollention = null; genCollention=new Generics<ArrayList>(new ArrayList()); System.out.println("能够编译通过并执行!"); }


1、假设仅仅指定了<?

>,而没有extends,则默认是同意Object及其下的不论什么Java类了。也就是随意类。


2、通配符泛型不单能够向下限制。如<? extends Collection>,还能够向上限制,如<? super Double>。表示类型仅仅能接受Double及其上层父类类型,如Number、Object类型的实例。
3、泛型类定义能够有多个泛型參数,中间用逗号隔开,还能够定义泛型接口,泛型方法。这些都与泛型类中泛型的使用规则相似。


多接口限制
尽管Java泛型简单的用 extends 统一的表示了原有的 extends 和 implements 的概念。但仍要遵循应用的体系,Java 仅仅能继承一个类,但能够实现多个接口,所以你的某个类型须要用 extends 限定。且有多种类型的时候。仅仅能存在一个是类,而且类写在第一位,接口列在后面。也就是:<T extends SomeClass & interface1 & interface2 & interface3>

这里的样例仅演示了泛型方法的类型限定,对于泛型类中类型參数的限制用全然一样的规则。仅仅是加在类声明的头部。如:

	public class Demo<T extends Comparable & Serializable>{
		//T类型就能够用Comparable声明的方法和Seriablizable所拥有的特性了
	}


最后再强调一点。就是泛型最关键的数据就是提高了代码的安全性,由于它能够在编译期对代码进行检查,从而避免了非常多在执行期强转类型发生的异常。

了解了泛型出现的目的,相信你也就知道该怎么使用泛型了吧!