1.新旧替换,使用一个新的容量更大的数组来接收旧的数组中的数据
1.1 遍历数组进行值的交换
//旧数组
int[] a = {1,2,3,4,5};
//新数组
int[] b = new int[a.length*2];
//将旧数组的值遍历传给新数组
for(int i=0;i<a.length;i++) {
b[i]=a[i];
}
a = b;
1.2 使用 System.arraycopy(src, srcPos, dest, destPos, length);来进行赋值,其实就是替换了循环遍历的过程。
这个方法的参数含义分别为:
src:旧数组;
srcPos:从旧数组的哪个下标开始
dest:新的数组
destPos: 从新的数组哪个下标开始接收数据
length: 要复制的长度为多少
//旧数组
int[] a = {1,2,3,4,5};
//新数组
int[] b = new int[a.length*2];
System.arraycopy(a, 0, b, 0, a.length);
a = b;
新旧替换的方法需要一个新的数组,且将新的数组的地址重新再赋给旧数组,这样一来不仅麻烦,而且繁琐。
2.直接扩容并且将地址直接返回给原来的数组
int[] a = {1,2,3,4,5};
//新数组
a = Arrays.copyOf(a, a.length*2);
这里用到的工具需要声明一下,但明显更加简单,可以直接将数组的地址返回给原来的数组
Arrays.copyOf(original, newLength);
这个方法的参数为:
original: 原数组
newLength: 新的长度
这个方法会在堆中重新开辟一块空间,并且将原数组的值复制进去,同时会返回该空间的地址。这个时候自然就可以使用原先的数组来接收该地址,完成数组扩容的行为。