1700443540
1700443541
public static<T>List<T>asList(T……a){
1700443542
1700443543
return new ArrayList<T>(a);
1700443544
1700443545
}
1700443546
1700443547
asList方法输入的是一个泛型变长参数,我们知道基本类型是不能泛型化的,也就是说8个基本类型不能作为泛型参数,要想作为泛型参数就必须使用其所对应的包装类型。那前面的例子传递了一个int类型的数组,为什么程序没有报编译错呢?
1700443548
1700443549
在Java中,数组是一个对象,它是可以泛型化的,也就是说我们的例子是把一个int类型的数组作为了T的类型,所以转换后在List中就只有一个类型为int数组的元素了,我们打印出来看看,代码如下:
1700443550
1700443551
public static void main(String[]args){
1700443552
1700443553
int[]data={1,2,3,4,5};
1700443554
1700443555
List list=Arrays.asList(data);
1700443556
1700443557
System.out.println(“元素类型:”+list.get(0).getClass());
1700443558
1700443559
System.out.println(“前后是否相等:”+data.equals(list.get(0)));
1700443560
1700443561
}
1700443562
1700443563
输出的结果是:
1700443564
1700443565
元素类型:class[I
1700443566
1700443567
前后是否相等:true
1700443568
1700443569
很明显,放在列表中的元素是一个int数组,可能有读者要问了,为什么“元素类型:”后的class是“[I”?我们并没有指明是数组(Array)类型呀!这是因为JVM不可能输出Array类型,因为Array是属于java.lang.reflect包的,它是通过反射访问数组元素的工具类。在Java中任何一个数组的类都是“[I”,究其原因就是Java并没有定义数组这一个类,它是在编译器编译的时候生成的,是一个特殊的类,在JDK的帮助中也没有任何数组类的信息。
1700443570
1700443571
弄清楚了问题,修改方案也就诞生了,直接使用包装类即可,代码如下:
1700443572
1700443573
public static void main(String[]args){
1700443574
1700443575
Integer[]data={1,2,3,4,5};
1700443576
1700443577
List list=Arrays.asList(data);
1700443578
1700443579
System.out.println(“列表中的元素数量是:”+list.size());
1700443580
1700443581
}
1700443582
1700443583
仅仅修改了加粗字体部分,把int替换为Integer即可让输出元素数量为5。需要说明的是,不仅仅是int类型的数组有这个问题,其他7个基本类型的数组也存在相似的问题,这就需要读者注意了,在把基本类型数组转换成列表时,要特别小心asList方法的陷阱,避免出现程序逻辑混乱的情况。
1700443584
1700443585
注意 原始类型数组不能作为asList的输入参数,否则会引起程序逻辑混乱。
1700443586
1700443587
1700443588
1700443589
[
上一页 ]
[ :1.70044354e+09 ]
[
下一页 ]