以前在写new ArrayList<>()时,后面的括号内一般没写过内容,但某天在刷力扣题时,发现有这样一个写法:
List<List<Integer>> list=new ArrayList()<>;
//此处Path为一个ArrayList类型的数组
list.add(new ArrayList<>(path))
于是就很疑惑,为什么要这样写, new ArrayList<>(path)执行之后到底是个什么样的,于是点开源码,源码如下:
public ArrayList(Collection<? extends E> c) {
elementData = c.toArray();
if ((size = elementData.length) != 0) {
// c.toArray might (incorrectly) not return Object[] (see 6260652)
if (elementData.getClass() != Object[].class)
//这里是重点!copyOf:也就是将传入的参数复制一份
elementData = Arrays.copyOf(elementData, size, Object[].class);
} else {
// replace with empty array.
this.elementData = EMPTY_ELEMENTDATA;
}
}
也就知道了作者的意图:力扣的该题涉及到回溯,也就是每次有满足条件的结果就会被存入List,不满足就回溯,如果直接写 list.add(path),因为path为一个引用类型,即内存中只有一份,那么每一次list所add的path都是取得同一个path,即后面path的每一个改变均会对list.add(path)中的path有影响(会导致最终每次存入的path都是同一个值)。