【Java源码分析】Arrays.asList源码分析
类型转换
int[] arr1 = {1, 2, 3};
List list1 = Arrays.asList(arr1);
System.out.println(list1);
Integer[] arr2 = {1, 2, 3};
List<Integer> list2 = Arrays.asList(arr2);
System.out.println(list2);
运行结果如下:
[[I@2503dbd3]
[1, 2, 3]
由此可见,当int[]作为Arrays.asList(T… a)的参数时,方法会将int[]看作一个对象。这样无法将基本类型的数组转换为对应的包装类型的集合。
因此,要实现int[] –> ArrayList<Integer>的转换,需要自己编码实现,如下:
int[] arr2 = {1, 2, 3};
List<Integer> list2 = new ArrayList<>(arr2.length);
for (int ele: arr2) list2.add(ele);
添加和删除元素
往由Arrays.asList()方法转换的List对象中添加元素,则会抛出 java.lang.UnsupportedOperationException
Integer[] arr = {1, 2, 3};
List<Integer> list = Arrays.asList(arr);
System.out.println(list);
list.set(2, 33); // ok
// list.remove(2); // UnsupportedOperationException
// list.add(4); // UnsupportedOperationException
分析原因
Arrays.asList(T… a)的源码如下:
public static <T> List<T> asList(T... a) {
return new ArrayList<>(a);
}
ArrayList(T… a)的源码如下:
private static class ArrayList<E> extends AbstractList<E>
implements RandomAccess, java.io.Serializable
{
private static final long serialVersionUID = -2764017481108945198L;
private final E[] a;
ArrayList(E[] array) {
a = Objects.requireNonNull(array);
}
……
}
需要指明的是,此处的ArrayList类并不是java.util.ArrayList,而是Arrays中的内部类。
该类继承了java.util.AbstractList,并且覆写其部分方法,比如set,get方法,但是没有覆写add和remove方法,而AbstractList中的add和remove的方法源码如下:
public void add(int index, E element) {
throw new UnsupportedOperationException();
}
public E remove(int index) {
throw new UnsupportedOperationException();
}
因此,当执行 list.remove(2); 会抛出 UnsupportedOperationException这个异常。
参考:
Arrays/AbstractList源码