Java:数组的扩容(三种解决方案)

import java.util.Arrays;

public class CopyArrayDemo {

	public static void main(String[] args) {
		int[] arr = { 1, 2, 3, 4, 5 };
		// 数组扩容(一)
		// int[] arr = {1,2,3,4,5}; //数组arr的下标分别为:0 1 2 3 4
		int[] arr_new = new int[6]; // 数组arr_new的下标分别为:0 1 2 3 4 5
		for (int i = 0; i < arr.length; i++) {    //遍历一遍,将数组arr的值传入数组arr_new中
			arr_new[i] = arr[i];    
		}
		// 为新数组赋值
		arr_new[arr_new.length - 1] = 6;
		for (int a : arr_new) {
			System.out.print(a + " ");
		}
		System.out.println();                //换行

		// 数组扩容(二)
		// 第一个参数是拷贝的数组,第二个参数扩容长度,并且返回一个新的数组
		int[] copyOf = Arrays.copyOf(arr, arr.length * 2);
		for (int a : copyOf) {
			System.out.print(a + " ");
		}
		System.out.println();                //换行
		
		// 数组扩容(三)
		int arr2[] = { 10, 20, 30, 40, 50, 60, 70, 80, 90 };
		/*
		 * src:表示复制的源数组
		 * srcPos:代表从源数组哪一个元素开始复制(下标)
		 * dest:目标数组
		 * destPos:从目标数组的哪一个元素开始粘贴源数组的数据
		 * length:复制源数组的长度是多少
		 */
		System.arraycopy(arr, 1, arr2, 3, arr.length - 1);
		for (int a : arr2) {
			System.out.print(a + " ");
		}
	}

}

执行结果为:

Java:数组的扩容(三种解决方案)_第1张图片

       

你可能感兴趣的:(计算机基础,java,排序算法,算法)