java泛型认知

特性:

  泛型只在编译阶段有效。

  

/**
 * 
 * @author 11
 *测试泛型只在编译阶段有效果,运行期间没有区别
 */
public class Demo1 {
    
    @SuppressWarnings("unused")
    public void test(){
        List<String> listString = new ArrayList<String>();
        List<Integer>listInteger = new ArrayList<Integer>();
        System.out.print(listString.getClass());
        System.out.print(listInteger.getClass());
    }
    
    public static void main(String arg[]) {
        Demo1 demo = new Demo1();
        demo.test();
    }
}

class java.util.ArrayList
class java.util.ArrayList

在编译过程中,正确检验泛型结果后,会将泛型的相关信息擦出,并且在对象进入和离开方法的边界处添加类型检查和类型转换的方法。也就是说,泛型信息不会进入到运行时阶段。

对此总结成一句话:泛型类型在逻辑上看以看成是多个不同的类型,实际上都是相同的基本类型。

  泛型的使用

  泛型的三种使用方法:泛型类、泛型方法、泛型接口

泛型类:

  泛型类型用于类的定义中,被称为泛型类。通过泛型可以完成对一组类的操作对外开放相同的接口

  class 类名称 <泛型标识:可以随便写任意标识号,标识指定的泛型的类型>

    { private 泛型标识 /*(成员变量类型)*/ var; ..... } }

  泛型语法,是不是看的头有点晕

  最普通的泛型类实例

  

package com.generic;

public class Demo2<T> {
    
    private T key;
    
    public Demo2(T key) {
        this.key = key;
    }
    
    public T getKey() {
        return key;
    }
    
    public static void main(String arg[]) {
        Demo2<String> demo = new Demo2<String>("小米");
        demo.getKey();
        
        System.out.println(Demo2.class);
    }

}

class com.generic.Demo2

//泛型的类型参数只能是类类型(包括自定义类),不能是简单类型

//传入的实参类型需与泛型的类型参数类型相同,即为Integer.

泛型类的用途,其实就是跟方法重载一样,你不确定的类的属性类型,就可以 使用泛型类。用途蛮大的

泛型接口:

  泛型接口与泛型类的定义及使用基本相同。泛型接口常被用在各种类的生产器中

  

  //定义一个泛型接口 public interface Generator<T>

            { public T next(); }

/**
 * 未传入泛型实参时,与泛型类的定义相同,在声明类的时候,需将泛型的声明也一起加到类中
 * 即:class FruitGenerator<T> implements Generator<T>{
 * 如果不声明泛型,如:class FruitGenerator implements Generator<T>,编译器会报错:"Unknown class"
 */
class FruitGenerator<T> implements Generator<T>{
    @Override
    public T next() {
        return null;
    }
}
/**
 * 传入泛型实参时:
 * 定义一个生产器实现这个接口,虽然我们只创建了一个泛型接口Generator<T>
 * 但是我们可以为T传入无数个实参,形成无数种类型的Generator接口。
 * 在实现类实现泛型接口时,如已将泛型类型传入实参类型,则所有使用泛型的地方都要替换成传入的实参类型
 * 即:Generator<T>,public T next();中的的T都要替换成传入的String类型。
 */
public class FruitGenerator implements Generator<String> {

    private String[] fruits = new String[]{"Apple", "Banana", "Pear"};

    @Override
    public String next() {
        Random rand = new Random();
        return fruits[rand.nextInt(3)];
    }
}

//这也不是一个泛型方法,这也是一个普通的方法,只不过使用了泛型通配符?

//同时这也印证了泛型通配符章节所描述的,?是一种类型实参,可以看做为Number等所有类的父类

  public void showKeyValue2(Generic<?> obj)

    { Log.d("泛型测试","key value is " + obj.getKey()); }

//可以把 ?想象成Object

 可以解决当具体类型不确定的时候,这个通配符就是 ?  ;当操作类型时,不需要使用类型的具体功能时,只使用Object类中的功能。那么可以用 ? 通配符来表 未知类型。

泛型方法:

    泛型类,是在实例化类的时候指明泛型的具体类型;泛型方法,是在调用方法的时候指明泛型的具体类型 。

  

原文地址:https://www.cnblogs.com/wuheng-123/p/13934130.html