泛型:
JDK1.5版本以后出现新特性。用于解决安全问题,是一个类型安全机制。
好处
1.将运行时期出现问题ClassCastException,转移到了编译时期。方便于程序员解决问题。让运行时问题减少,安全。,
2,避免了强制转换麻烦。
泛型格式:通过<>来定义要操作的引用数据类型。
在使用java提供的对象时,什么时候写泛型呢?
通常在集合框架中很常见,
只要见到<>就要定义泛型。
其实<> 就是用来接收类型的。
当使用集合时,将集合中要存储的数据类型作为参数传递到<>中即可。
什么时候定义泛型类?
当类中要操作的引用数据类型(八大基本类型和void不属于此范围)不确定的时候,早期定义Object来完成扩展。现在定义泛型来完成扩展。
泛型类定义的泛型,在整个类中有效。如果被方法使用,
那么泛型类的对象明确要操作的具体类型后,所有要操作的类型就已经固定了。
/*
class Demo<T>
{
publicvoid show(T t)
{
System.out.println("show:"+t);
}
publicvoid print(T t)
{
System.out.println("show:"+t);
}
}
*/
为了让不同方法可以操作不同类型,而且类型还不确定。
那么可以将泛型定义在方法上。
*/
class Demo<T>//泛型类
{
public void show(T t)
{
System.out.println("show:"+t);
}
public<Q> void print(Q q)
{
System.out.println("print:"+q);
}
public static <W> void method(W t) //泛型方法
{
System.out.println("method:"+t);
}
}
特殊之处:
静态方法不可以访问类上定义的泛型。
如果静态方法操作的应用数据类型不确定,可以将泛型定义在方法上。
泛型类中只存在静态的泛型方法,而没有属于类级别的泛型静态方法。
例子:
classDemo<T>
{
public static <W> void method (Wt){//静态泛型方法
System.out.println(“method:”+t);
}
public void show(T t){//属于类的泛型方法
System.out.println(“show:”+t);
}
public static <Q> void print (Q t){
System.out.println(“print:”+t);
}
/* public static void method( ){// 静态方法不可以访问类上定义的泛型
Print();
}
public static void method_1 (T t){ //不能有属于类级别的泛型静态方法。
System.out.println(“method:”+t);
}
*/
}
? 通配符。也可以理解为占位符。
泛型的限定;
? extends E: 可以接收E类型或者E的子类型。上限。
? super E: 可以接收E类型或者E的父类型。下限
泛型内部原理了解:
泛型只是给编译器看的,例如:
Aarrylist<String> collection1= newAarrylist<String>();
Aarrylist<Integer> collection2= new Aarrylist<String>();
System.out.println(collection1.getClass()==collection2.getClass());//true
因为编译通过后就会去掉<String><Integer>,最后两者生成的字节码就一样了,共用的是同一份字节码。
泛型中的参数类型推断: