arraylist add(int index) 方法时 index是处于前半部分还是后半部分效率高
来源:互联网 发布:怎样下载cad软件 编辑:程序博客网 时间:2024/05/20 06:24
- public void add(int index, E element) {
- if (index > size || index < 0)
- throw new IndexOutOfBoundsException(
- "Index: "+index+", Size: "+size);
- ensureCapacity(size+1); // Increments modCount!!
- System.arraycopy(elementData, index, elementData, index + 1,
- size - index);
- elementData[index] = element;
- size++;
- }
- 看源码就知道了,无论传入的是哪个index,都要进过if判断,
- 假如不超过容量,看这个System.arraycopy,这其实是个native方法,方法我们发现实现的是自我复制,首先用临时数组把index后的数据取走然后再拷回到index+1ao后面,此时我们分析下,如果加在最前,那所有数据都需要用中间临时数组拷贝走,再拷贝回来,如果加在最后,length=0,就不需要用到临时数组了,直接加进来即可继续看System.arraycopy源码,这是一个本地方法,代码见http://www.360doc.com/content/14/0713/19/1073512_394157835.shtml,
- 可以看到length=0时,直接返回,
- 当大于0时最后用到了c语言的void *memmove(void *dst, const void *src, size_t count)函数。
- 所以说加到后半部分是优于加到前半部分的。
- 同时这也说明了arraylist的add()无index方法加到最后的原因,此时无需中间数组,也少了一次本地方法调用。
- 这是add()无index参数的源码
- public boolean add(E e) {
ensureCapacityInternal(size + 1);
elementData[size++] = e;
return true;
}
- remove也是这样,后半部分比前半部分效率高
0 0
- arraylist add(int index) 方法时 index是处于前半部分还是后半部分效率高
- java.util.ArrayList.add(int index, E elemen)方法实例
- ArrayList.add(int index, E element)
- JAVA ArrayList集合add(int index, E element)方法源码简单分析
- ArrayList.add(int index, E e)的数组越界
- Java ArrayList 不为人知的陷阱,及add(int index, E element)和set(int index, E element)两个方法的说明
- mysql index部分错误
- listIterator(int index)方法
- arraylist中set(index,object)与add(index,object)方法的区别
- lucene源代码分析(index部分)
- lucene源代码分析(index部分)
- Java ArrayList add(index,element) 方法插入元素到数组指定位置
- Java ArrayList add(index,element) 方法插入元素到数组指定位置
- ArrayList的方法:remove(object o) 、remove(int index)、removeAll(Collection c)时间复杂度的比较
- 算法实现数组前半部分为奇数,后半部分为偶数。
- 数组前半部分和后半部分有序列的全排序
- 输入整数数组,调整顺序,使得奇数位于前半部分,偶数位于后半部分
- ArrayList.add(index, element)失败,都是size的误解
- Scala深入浅出实战经典:39,ListBuffer、ArrayBuffer、Queue、Stack操作代码实战
- 【c++ templates读书笔记】【1】函数模板
- Hibernate 应用
- Android SDK Manager
- Scala深入浅出实战经典:40,Set、Map、TreeSet、TreeMap操作代码实战
- arraylist add(int index) 方法时 index是处于前半部分还是后半部分效率高
- NYOJ -2括号配对问题
- Node.js中的Net模块
- https https和http区别,https证书分为哪几类?
- Android教程-01 Android Studio创建第一个项目
- Linux下线程同步的几种方法
- 方法重载和方法覆盖/重写的区别
- CSS样式 --- 鼠标光标样式 【时刻更新】
- leetcode | Valid Palindrome