泛型:

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>,最后两者生成的字节码就一样了,共用的是同一份字节码。

泛型中的参数类型推断:

java 泛型实验报告 java泛型集合实验心得_java