java中的System.arraycopy方法

今天在看hbase源码,看到了System.arraycopy方法,学习了一下:

java中的ArrayList是动态数组,其优点就是查询速度快,插入和删除速度慢,就是因为它是数组形式,有位置索引,所以在查询的时候可以根据下标索引直接找到对应元素,但是在插入和删除元素的时候,需要挪动数组,所以速度较慢。深查其java源码,可以发现ArrayList中其实就用到了System.arraycopy方法。

ArrayList中的add操作的源码:

Add 方法

public void add(int index, E element) {

  if (index > size || index < 0)

       throw new IndexOutOfBoundsException( "Index: "+index+", Size: "+size);

  ensureCapacity(size+1); // Increments modCount!!

  System.arraycopy(elementData, index, elementData, index + 1, size - index);

  elementData[index] = element;

  size++;

}
ArrayList中的remove方法的源码:

public E remove(int index) {

  RangeCheck(index);

  modCount++;

  E oldValue = elementData[index];

  int numMoved = size - index - 1;

  if (numMoved > 0)

      System.arraycopy(elementData, index+1, elementData, index, numMoved);

  elementData[--size] = null; // Let gc do its work

  return oldValue;

}
上述源码其实就是实现了数组对象的自我复制。

System.arrayCopy这个方法是System类中的一个JNI方式实现类。

其函数原型是:

  public static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length)

src:源数组;

srcPos:源数组要复制的起始位置;

dest:目的数组;

destPos:目的数组放置的起始位置;

length:复制的长度。

注意:src and dest都必须是同类型或者可以进行转换类型的数组。

有趣的是这个函数可以实现自己到自己复制

但是在copy二维数组的时候,容易出问题。

java其实没有二维数组的概念,平常实现的二维数组只是元素是一维数组的一维数组,而数组也是引用类型,继承自Object类。数组是new出来的。这些性质也就导致arraycopy()二维数组时出现的问题。 

如果是一维数组,那么元素都是基础类型(如int,double等),使用arraycopy()方法后,是把原数组的值传给了新数组,属于值传递。而如果是二维数组,数组的第一维装的是一个一维数组的引用,第二维里是元素数值。对二维数组应用arraycopy()方法后,第一维的引用被复制给新数组的第一维,也就是两个数组的第一维都指向相同的“那些数组”。而这时改变其中任何一个数组的元素的值,其实都修改了“那些数组”的元素的值,所以原数组和新数组的元素值都一样了。

LinkedList则使用一个Entry的内部类,其有指向next和previous的引用保存元素,它的遍历则先计算出所需index和size>>1(以为后的大小),确定是通过previous还是next遍历。

### 回答1: system.arraycopyJava的一个方法,用于将一个数组的元素复制到另一个数组。它的语法如下: System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length) 其,src表示源数组,srcPos表示源数组要复制的起始位置,dest表示目标数组,destPos表示目标数组要复制的起始位置,length表示要复制的元素个数。这个方法可以用来实现数组的复制、合并、截取等操作。 ### 回答2: Java的system.arraycopy是一个非常有用的方法,它可以用来复制数组的一部分到另一个数组。它的语法如下: ``` public static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length) ``` 其,src是源数组,srcPos是源数组的起始位置,dest是目标数组,destPos是目标数组的起始位置,length是要复制的元素个数。 这个方法可以用于任意类型的数组,包括基本类型和引用类型。当源数组和目标数组的类型不同时,需要进行强制类型转换。 在使用system.arraycopy时需要注意一些细节。首先,源数组和目标数组必须有足够的空间来容纳复制的元素。其次,复制操作不会改变源数组的内容,只会改变目标数组。如果需要改变源数组,需要手动进行赋值操作。另外,当复制的元素个数超过数组长度时,会抛出ArrayIndexOutOfBoundsException异常。最后,如果源数组和目标数组引用的是同一个数组,可能会导致不正确的结果。 总的来说,system.arraycopy是一个非常高效、安全的数组复制方法,能够有效地提高代码的性能和可读性。在实际开发,我们可以根据需要灵活地使用它。 ### 回答3: system.arraycopyJava语言的数组拷贝方法。该方法的语法为: ``` public static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length) ``` 其,src表示源数组,srcPos表示源数组的起始位置,dest表示目标数组,destPos表示目标数组的起始位置,length表示要拷贝的元素数量。 该方法可以对任何类型的数组进行拷贝操作,包括基本类型数组和引用类型数组。拷贝操作的过程是将源数组指定位置的元素复制到目标数组指定位置,如果源数组和目标数组重合,则会造成数据的覆盖。 需要注意的是,如果源数组和目标数组的类型不一致,则会抛出ArrayStoreException异常;如果数组下标越界,则会抛出IndexOutOfBoundsException异常。 使用system.arraycopy方法可以提高数组拷贝的效率,因为它直接操作数组的内存,避免了数组元素的逐一复制操作。此外,该方法还可以实现数组的截取、扩容以及数组的合并等功能。 总之,system.arraycopyJava语言非常实用的数组拷贝方法,可以方便地实现数组操作,提高程序的效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值