博客分类:
居然也碰到这个陷阱的问题了,查了下书,终于解决,大概讲解如下,
代码如下:
- public static void main(String[] args) {
- int[] data = {1,2,3,4,5};
- List list = Arrays.asList(data);
- System.out.println("列表中的元素数量是:" + list.size());
- }
public static void main(String[] args) { int[] data = {1,2,3,4,5}; List list = Arrays.asList(data); System.out.println("列表中的元素数量是:" + list.size()); }
注意这里输出的数量是1,原因是,在Arrays.asList中,其接收的参数原型其实是泛型变长参数来的,而基本类型是不能作为范型的参数,按道理应该使用包装类型,但这里缺没有报错,
因为数组是可以泛型化的,所以转换后在list中就有一个类型为int的数组
- int[] data = {1,2,3,4,5};
- List list = Arrays.asList(data);
- System.out.println("元素类型:" + list.get(0).getClass());
- System.out.println("前后是否相等:"+data.equals(list.get(0)));
int[] data = {1,2,3,4,5}; List list = Arrays.asList(data); System.out.println("元素类型:" + list.get(0).getClass()); System.out.println("前后是否相等:"+data.equals(list.get(0)));
可以看到,输出的为元素类型:class [I
因为jvm不可能输出array类型,array类型属于java.lang.reflect包,通过反射访问
数组的这个类,编译时候生成的。所以要改为:
- Integer[] data = {1,2,3,4,5};
- List list = Arrays.asList(data);
- System.out.println("列表中的元素数量是:" + list.size());
Integer[] data = {1,2,3,4,5}; List list = Arrays.asList(data); System.out.println("列表中的元素数量是:" + list.size());
此外,假如如下代码:
- //枚举,声明一个星期
- enum Week{Sun,Mon, Tue, Wed,Thu,Fri,Sat}
- public static void main(String[] args) {
- //工作日
- Week[] workDays = {Week.Mon, Week.Tue, Week.Wed,Week.Thu,Week.Fri};
- //转换为列表
- List<Week> list = Arrays.asList(workDays);
- //增加周六也为工作日
- list.add(Week.Sat);
//枚举,声明一个星期 enum Week{Sun,Mon, Tue, Wed,Thu,Fri,Sat} public static void main(String[] args) { //工作日 Week[] workDays = {Week.Mon, Week.Tue, Week.Wed,Week.Thu,Week.Fri}; //转换为列表 List<Week> list = Arrays.asList(workDays); //增加周六也为工作日 list.add(Week.Sat);
注意这里用add会出错,因为是arrays.aslist中,看代码可以看到这里返回的
ArrayList不是原来的传统意义上的java.util.arraylist了,而是自己工具类的一个
静态私有内部类,并没有提供add方法,要自己实现,所以这里是出错了,因此,
除非确信array.aslist后长度不会增加,否则谨慎使用:
还有就是因为此处的array.asList 底层的实现是一个固定大小的数组,所以生成的list仅仅是可以进行哪些不改变数组大小的操作因此
List<String> abc=Arrays.asList("a","b","c"),因为这样的长度是无法再add的了
时间: 2024-10-27 10:35:10