就是指编译器编译带类型说明的集合时会去掉“类型”信息
泛型是提供给javac编译器使用的,限定集合的输入类型,编译器编译带类型说明的集合时会去掉“类型”信息。
public class GenericTest {
public static void main(String[] args) {
new GenericTest().testType();
}
public void testType(){
ArrayList<Integer> collection1 = new ArrayList<Integer>();
ArrayList<String> collection2= new ArrayList<String>();
System.out.println(collection1.getClass()==collection2.getClass());
//两者class类型一样,即字节码一致
System.out.println(collection2.getClass().getName());
//class均为java.util.ArrayList,并无实际类型参数信息
}
}
输出
true
java.util.ArrayList
为何会返回true
使用反射可跳过编译器,往某个泛型集合加入其它类型数据。
public class GenericTest {
public static void main(String[] args) {
swap(new String[]{"111","222"},0,1);//编译通过
//swap(new int[]{1,2},0,1);
//编译不通过,因为int不是引用类型
swap(new Integer[]{1,2},0,1);//编译通过
}
/*交换数组a 的第i个和第j个元素*/
public static <T> void swap(T[]a,int i,int j){
T temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
但注意基本类型有时可以作为实参,因为有自动装箱和拆箱。
public class GenericTest {
public static void main(String[] args) {
new GenericTest().testType();
int a = biggerOne(3,5);
//int 和 double,取交为Number
Number b = biggerOne(3,5.5);
//String和int 取交为Object
Object c = biggerOne("1",2);
}
//从x,y中返回y
public static <T> T biggerOne(T x,T y){
return y;
}
}
Error:(17, 29) java: 不兼容的类型: 推断类型不符合上限
推断: java.lang.Number&java.lang.Comparable<? extends java.lang.Number&java.lang.Comparable<?>>
上限: java.lang.String,java.lang.Object
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。