面对不同的类型,如果具有相同的解决逻辑,我们就用同一套东西去解决,只不过在真正用的时候指定一下它要面对的类型
1、参数化类型机制:即将类型参数化,类似方法中的变量参数。
容器类可以算是最具重用性的类库,包含了泛型的定义
List<String> list = new ArrayList<String>();
//此处就是讲String类型作为一个参数
list.add("jdhk");
//list.add(1); 编译会出错,1 不是Sting类型
2、泛型接口/类/方法
a. 下面的泛型类就和容器类实现方式相同
public class GenericTest {
public static void main(String[] args) {
Box<String> name = new Box<String>("corn");
Box<Integer> age = new Box<Integer>(712);
System.out.println("name class:" + name.getClass()); // com.qqyumidi.Box
System.out.println("age class:" + age.getClass()); // com.qqyumidi.Box
System.out.println(name.getClass() == age.getClass()); // true
}
}
此中的String和Interger相当于覆盖了下面的T
public class GenericTest {
public static void main(String[] args) {
Box<String> name = new Box<String>("corn");
System.out.println("name:" + name.getData());
}
}
class Box<T> {
private T data;
public Box() {
}
public Box(T data) {
this.data = data;
}
public T getData() {
return data;
}
}