24

在 JDK 1.7 中,有一个ArrayListasList.

为什么他们制造了一个新的private static class而不是使用java.util.ArrayList

@SafeVarargs
public static <T> List<T> asList(T... a) {
    return new ArrayList<>(a);
}

/**
 * @serial include
 */
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) {
        if (array==null)
            throw new NullPointerException();
        a = array;
    }

    public int size() {
        return a.length;
    }

    public Object[] toArray() {
        return a.clone();
    }

    public <T> T[] toArray(T[] a) {
        int size = size();
        if (a.length < size)
            return Arrays.copyOf(this.a, size,
                                 (Class<? extends T[]>) a.getClass());
        System.arraycopy(this.a, 0, a, 0, size);
        if (a.length > size)
            a[size] = null;
        return a;
    }

    public E get(int index) {
        return a[index];
    }

    public E set(int index, E element) {
        E oldValue = a[index];
        a[index] = element;
        return oldValue;
    }

    public int indexOf(Object o) {
        if (o==null) {
            for (int i=0; i<a.length; i++)
                if (a[i]==null)
                    return i;
        } else {
            for (int i=0; i<a.length; i++)
                if (o.equals(a[i]))
                    return i;
        }
        return -1;
    }

    public boolean contains(Object o) {
        return indexOf(o) != -1;
    }
}
4

5 回答 5

27

因为List返回的由Arrays.asList()给定数组支持。它包装了那个数组;对数组的更改反映在List反之亦然。

此外,因此,List此处返回的大小是固定的。所以,它不可能是ArrayList因为ArrayList可以增长或缩小。

于 2013-11-05T14:06:33.300 回答
4

因为默认ArrayList没有ArrayList(E[] array)构造函数。

于 2013-11-05T14:04:45.890 回答
3

因为他们在提供的数组周围提供了一个列表包装器,即 O(1),而不是从数组中的元素构建一个 ArrayList,即 O(n)。

这会给您带来问题吗?如果是这样,可能是因为您在应该使用 List 时将变量声明为 ArrayList

于 2013-11-05T14:07:07.180 回答
2

这些asList(T... a)方法被声明为返回一个由指定数组支持的固定大小的列表,该数组也应该是可序列化的并实现RandomAccess

java.util.ArrayList不符合此定义(固定大小),因此java.util.List应使用另一种类型。

于 2013-11-05T14:14:17.807 回答
-1

如果您使用 ArrayList,请从 Table 中快速检索数据,因为它是基于索引的,我们想要快速检索数据的地方可以使用 Arraylist ....

但是 ArrayList 在删除记录时并不快,因为重新排列索引更复杂

在我们想要更多删除记录的地方,我们可以使用 LinkedList 它不是基于索引的

数组列表声明

java.util.List

ArrayList arrayList = new ArrayList();

于 2013-11-05T14:37:09.770 回答