我从同一个数组创建了两个列表并对其中一个进行了排序.当我尝试更改一个列表时,其他列表也已更新.
List<Integer> list = Arrays.asList(ar); List<Integer> sorted = Arrays.asList(ar); Collections.sort(sorted); list.set(0,10000000); //changes sorted also
我花了一段时间才弄明白,下面提到的代码工作了.
列表与LT;整数> sorted = new ArrayList< Integer>(Arrays.asList(ar));
我想知道为什么我的第一种方法不起作用?我创建了两个单独的列表,为什么这两个列表都发生了变化. java如何在这里为变量赋值?
解决方法
从Arrays.asList的Java文档:
Returns a fixed-size list backed by the specified array. (Changes to the returned list “write through” to the array.) This method acts as bridge between array-based and collection-based APIs,in combination with
Collection.toArray()
. The returned list is serializable and implementsRandomAccess
.
因此,当您更改列表中的某些内容时,它会“写入”到底层数组ar,这也是已排序的基础数组,因此更改也会反映在已排序中.
此外,asList的代码是:
public static <T> List<T> asList(T... a) { return new ArrayList<T>(a); }
这是java.util.Arrays.ArrayList,它具有以下定义:
ArrayList(E[] array) { a = Objects.requireNonNull(array); }
重要的是a不复制,它是原始数组. java.util.ArrayList类具有以下构造函数
public ArrayList(Collection<? extends E> c) { elementData = c.toArray(); size = elementData.length; // c.toArray might (incorrectly) not return Object[] (see 6260652) if (elementData.getClass() != Object[].class) elementData = Arrays.copyOf(elementData,size,Object[].class); }
所以在java.util.ArrayList构造函数中,我们创建了每个元素的副本,而在java.util.Arrays.ArrayList中,我们没有.