使用sublist截取后,对获得的list进行remove操作,会影响原list
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add("1");
list.add("2");
list.add("3");
list.add("4");
list.add("5");
List<String> strings = list.subList(0, 2);
System.out.println("==remove=before"+list);
strings.remove("1");
System.out.println("==remove=after"+list);
}
结果:

原理:
subList是ArrayList的内部类,
public List<E> subList(int fromIndex, int toIndex) {
subListRangeCheck(fromIndex, toIndex, size);
return new SubList(this, 0, fromIndex, toIndex);
}
重点subList构造方法
SubList(AbstractList<E> parent,
int offset, int fromIndex, int toIndex) {
this.parent = parent;
this.parentOffset = fromIndex;
this.offset = offset + fromIndex;
this.size = toIndex - fromIndex;
this.modCount = ArrayList.this.modCount;
}
List由数组够成的。
this参数是指的是那个外部调用subList方法的那个List对象,其他都挺好理解的。注意的地方是subList是外部list的缩影只要改变sublist的值外部的list也会跟着改变,共享一份内存变量。
所以一般使用了subList最好不要去更改原来的list,一般只对其进行读操作。
本文探讨了在Java中使用ArrayList的subList方法截取子列表后,对子列表进行remove操作时对原始列表的影响。通过示例代码展示了subList与原始列表之间的内存共享特性,并给出了解决方案。
1014

被折叠的 条评论
为什么被折叠?



