Java小白一只,深信Java的一切都是对象,就连基本类型也都是对象。但是今天我点开ArrayList方法后,我看到了remove的两个方法:
public E remove(int var1) { this.RangeCheck(var1); ++this.modCount; Object var2 = this.elementData[var1]; int var3 = this.size - var1 - 1; if(var3 > 0) { System.arraycopy(this.elementData, var1 + 1, this.elementData, var1, var3); } this.elementData[--this.size] = null; return var2; } public boolean remove(Object var1) { int var2; if(var1 == null) { for(var2 = 0; var2 < this.size; ++var2) { if(this.elementData[var2] == null) { this.fastRemove(var2); return true; } } } else { for(var2 = 0; var2 < this.size; ++var2) { if(var1.equals(this.elementData[var2])) { this.fastRemove(var2); return true; } } } return false; }
对于深信一切都是对象的我,这简直是一个bomb,假如一切都是对象的话,那如果用int类型作为参数调用remove()方法时,那结果我岂不是不敢相信。
实践是检验真理的唯一方法,所以我开始了我的求真之路。
public class ListRemoveTest { public static void main(String[] args) { List<Integer> list1 = new ArrayList<Integer>(); List<Integer> list2 = new ArrayList<Integer>(); for (int a = -3; a < 3; a++) { list1.add(a); list2.add(a); } for (int a = 0; a < 3; a++) { list1.remove(a); list2.remove((Integer) a); } System.out.println(list1); System.out.println(list2); } }
但是输入结果为:
[-2, 0, 2]
[-3, -2, -1]
明显是不一样的,然后我细细的看了下源码,发现,上面
remove(int var1)
是删除list中的第几位的元素,而
是删除 list中的对于元素,remove(Object var1)
既然第一个是删除list中的第几位的元素,那为什么输出不是[0,1,2]呢,然后我再看看源代码发现remove(int varl)方法里面的
System.arraycopy(this.elementData, var1 + 1, this.elementData, var1, var3);
原来list移除第几位元素时,是将移除后的list拷贝到另外一个list上面,所以list1.remove(a)其实是执行了三遍,
原list是:[-3,-2,-1,0,1,2]
第一次返回的list是:[-2,-1,0,1,2],
然后再基于第一次返回的list,移除第二位,所以第二次返回的list:[-2,0,1,2],
然后再基于第二次返回的list,移除第三位,所以第二次返回的list:[-2,0,2]
所以最后返回的是[-2,0,2],
第一次写这么长,都跑偏了,但是归根结底:基本类型不是对象