java 1.7之后的Arraylist容量增长机制
2016-04-15 17:29
387 查看
一直以来都错误的理解Arraylist的容量自增长是添加一个元素容量自动加1,偶然的聊起这个话题,才发现貌似我理解错了,跑去看了Arraylist的源代码才清楚了它的容量自增长机制并不是我所认为的那样。下面是Arraylist容量增长的源代码,附上一些注释,如果有不正确的还希望大家能给纠正~~~
首先看一下ArrayList添加元素的方法:
下面就是实现扩容的相关方法了:
首先看一下ArrayList添加元素的方法:
public boolean add(E e) { ensureCapacityInternal(size + 1); // Increments modCount!! elementData[size++] = e; return true; }
下面就是实现扩容的相关方法了:
private void ensureCapacityInternal(int minCapacity) { if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) { minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity); } ensureExplicitCapacity(minCapacity); } private void ensureExplicitCapacity(int minCapacity) { modCount++;//定义于ArrayList的父类AbstractList,用于存储结构修改次数 // overflow-conscious code if (minCapacity - elementData.length > 0) grow(minCapacity); } private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;//有些虚拟机会在数组内保留一些头部信息,尝试分配更大的容量可能会导致内存溢出 //容量扩容的精髓 private void grow(int minCapacity) { // overflow-conscious code int oldCapacity = elementData.length; int newCapacity = oldCapacity + (oldCapacity >> 1);//当前容量的1.5倍赋值给新的容量 if (newCapacity - minCapacity < 0)//判断新容量是否足够,足够则使用当前新容量创建新数组,不够就将数组长度设置为需要的长度 newCapacity = minCapacity; if (newCapacity - MAX_ARRAY_SIZE > 0)//判断有没超过最大限制 newCapacity = hugeCapacity(minCapacity); //将原来数组的值copy新数组中去, ArrayList的引用指向新数组(如果数据量很大还是建议初始化的时候指定容量的大小,提高效率) elementData = Arrays.copyOf(elementData, newCapacity); }
相关文章推荐
- Java学习路线
- 2.Java之if语句及三目运算符
- Java中参数的引用传递和值传递
- 对于MyEclipse整合git上的maven项目导入
- spring mvc @ModelAttribute注解使用
- Dubbo java.io.IOException: Can not lock the registry cache file
- [转]Java8 lambda表达式及新特新
- Java泛型中的? super T语法
- Spring下对Quartz的使用
- eclipse几个注意的地方
- Java基础——关键字
- Java 往hashSet集合中存入自定义对象
- Spring MVC请求处理流程
- Spring MVC程序中得到静态资源文件css,js,图片文件的路径问题总结
- mybatis中的#和$的区别
- Java工程构建工具ANT与Maven的区别
- java学习总结(3)
- Spring事务配置的五种方式
- Java IO4:字符编码
- java截取字符串