本文主要是介绍解读ArrayList中的grow(int minCapacity)方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
查看源码:
/*** Increases the capacity to ensure that it can hold at least the* number of elements specified by the minimum capacity argument.** @param minCapacity the desired minimum capacity*/private void grow(int minCapacity) {// overflow-conscious codeint oldCapacity = elementData.length;int newCapacity = oldCapacity + (oldCapacity >> 1);if (newCapacity - minCapacity < 0)newCapacity = minCapacity;if (newCapacity - MAX_ARRAY_SIZE > 0)newCapacity = hugeCapacity(minCapacity);// minCapacity is usually close to size, so this is a win:elementData = Arrays.copyOf(elementData, newCapacity);}
由源码注释可得知,此方法用来保证数组至少可以容纳由minimum capacity参数指定的元素数。
大白话就是,容量要保证能装下mincapacity所指定的容量大小
源码分析
//把数组的长度赋给oldCapacity
int oldCapacity = elementData.length;
//新的数组容量=老的数组长度的1.5倍。oldCapacity >> 1 相当于除以2
int newCapacity = oldCapacity + (oldCapacity >> 1);
//如果新的数组容量newCapacity小于传入的参数要求的最小容量minCapacity,那么新的数组容量以传入的容量参数为准。
if (newCapacity - minCapacity < 0)
newCapacity = minCapacity;
//如果新的数组容量newCapacity大于数组能容纳的最大元素个数 MAX_ARRAY_SIZE 2^{31}-1-8
//那么再判断传入的参数minCapacity是否大于MAX_ARRAY_SIZE,如果minCapacity大于MAX_ARRAY_SIZE,那么//newCapacity等于Integer.MAX_VALUE,否者newCapacity等于MAX_ARRAY_SIZE
if (newCapacity - MAX_ARRAY_SIZE > 0)
newCapacity = hugeCapacity(minCapacity);
这里有3个判断:
- if (newCapacity - minCapacity < 0)
- if (newCapacity - MAX_ARRAY_SIZE > 0)
- 以及hugeCapacity(minCapacity);函数中的:
- (minCapacity > MAX_ARRAY_SIZE) ? Integer.MAX_VALUE : MAX_ARRAY_SIZE;
意义为:当重新计算的容量(x1.5那个计算)小于传入要求容量参数,则新容量以传入的比较大的容量参数为准。
当传入容量参数太大,大到超过了数组的容量限定值却又小于整数限定值 -1,那么新的数组容量以整数限定值 -1为准,但是当传入的容量参数不大于数组的容量限定值时,以容量限定值为准。
// minCapacity is usually close to size, so this is a win://MinCapacity通常接近size,所以这是一个胜利
//把旧数组放进新的扩容后的数组
elementData = Arrays.copyOf(elementData, newCapacity);
Integer.MAX_VALUE:整型的最大值 -1
/*** A constant holding the maximum value an {@code int} can* have, 2<sup>31</sup>-1.*/@Native public static final int MAX_VALUE = 0x7fffffff;
MAX_ARRAY_SIZE:
private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;
hugeCapacity:
传入的参数必须大于0,否者报错
判断传入的参数minCapacity是否大于MAX_ARRAY_SIZE,如果minCapacity大于MAX_ARRAY_SIZE
返回Integer.MAX_VALUE,否者返回MAX_ARRAY_SIZE。
private static int hugeCapacity(int minCapacity) {if (minCapacity < 0) // overflowthrow new OutOfMemoryError();return (minCapacity > MAX_ARRAY_SIZE) ?Integer.MAX_VALUE :MAX_ARRAY_SIZE;}
这篇关于解读ArrayList中的grow(int minCapacity)方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!