ArrayList和Arrays.ArrayList

2022-03-24  本文已影响0人  Leo_JiangZhiHao

先来看一段代码:

public static void test(){
    List<String> typeList = Arrays.asList("1,2,3,4".split(","));
    for (int i = 0; i < typeList.size(); i++) {
        String type = typeList.get(i);
        if("3".equals(type)){
            typeList.remove(i);
        }
    }
    System.out.println(typeList);
}

这段代码的typeList.remove(i)会抛出java.lang.UnsupportedOperationException异常。

asList()方法生成一个ArrayList,但是需要注意的是,这个ArrayList并不是ArrayList类,而是Arrays类里面的嵌套类Arrays.ArrayList类,该嵌套类如下:

private static class ArrayList<E> extends AbstractList<E> implements RandomAccess, java.io.Serializable

private final E[] a;

ArrayList(E[] array) {
    a = Objects.requireNonNull(array);
}

可见Arrays.ArrayList有一个数组成员 E[] a。Arrays.ArrayList的构造器直接让它的数组成员a指向了传进来的array。
只有这个Arrays.ArrayList的构造器能够接受数组作为构造器参数,ArrayList的构造器是只能接受Collection的。

也就是说,Arrays.ArrayList是没有add和remove方法的,并且修改元素也是通过修改之前传递进去的固定长度数组来实现。(本质还是数组)
Arrays.ArrayList继承自AbstractList,但没有重写add和remove方法,所以,删除时,会调用基类AbstractList的remove方法:

public E remove(int index) {
    throw new UnsupportedOperationException();
}

正确的写法:

public static void test(){
    List<String> typeList = new ArrayList<>(Arrays.asList("1,2,3,4".split(",")));
    for (int i = 0; i < typeList.size(); i++) {
        String type = typeList.get(i);
        if("3".equals(type)){
            typeList.remove(i);
        }
    }
    System.out.println(typeList);
}
上一篇下一篇

猜你喜欢

热点阅读