今天在学习数据结构的时候发现一个很好用的方法,今天来享一下
System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length) //将指定源数组中的数组从指定位置复制到目标数组的指定位置。
用于对数组的复制很方便,比如,删除数组中的一个元素时,然后这个元素后面的元素都要往前一个,如果没有这个函数,我们就的用循环来实现,下面我们来看看这两者的区别以及这个方法的好处
利用循环
public void delete(long value) {
int i = find(value);
if (i < 0) {
System.out.println("没有你要删除的元素");
} else {
int j;
for (j = i; j < nElements - 1; j++) {
arr[j] = arr[j + 1];
}
}
nElements--;
}
利用这个方法
public void delete(Object value) {
int i = find(value);
if(i<0) {
System.out.println("没有你要删除的元素");
}else {
System.arraycopy(arr, i+1, arr, i, nElemt-(i+1));
}
nElemt--;
}
以上两种代码都能实现相同的功能,,但是下面的明显代码量少,这就看起来比较舒服。
arraycopy(Object src, int srcPos, Object dest, int destPos, int length)这么多参数,那么这些参数具体都表示什么,
src - 源数组。
srcPos - 源数组中的起始位置。
dest - 目标数组。
destPos - 目的地数据中的起始位置。
length - 要复制的数组元素的数量。
再来代码演示一下这个方法的作用,非常好用
int arr []= {11,22,33,44,55,66};
int arr2 [] = new int[10];
arr2[0]=34;
arr2[1]=56;
arr2[2]=78;
arr2[3]=89;
//将arr中,22,33,44,55,复制到arr2 中
System.arraycopy(arr, 1, arr2, 4, 4);
for(Integer i : arr2) {
System.out.print(i+" ");
}
输出结果是
34 56 78 89 22 33 44 55 0 0