arraycopy-------From JDK6.0

public static void arraycopy(Object src,
int srcPos,
Object dest,
int destPos,
int length)
从指定源数组中复制一个数组,复制从指定的位置开始,到目标数组的指定位置结束。从 src 引用的源数组到 dest 引用的目标数组,数组组件的一个子序列被复制下来。被复制的组件的编号等于 length 参数。源数组中位置在 srcPossrcPos+length-1 之间的组件被分别复制到目标数组中的 destPosdestPos+length-1 位置。

如果参数 srcdest 引用相同的数组对象,则复制的执行过程就好像首先将 srcPossrcPos+length-1 位置的组件复制到一个带有 length 组件的临时数组,然后再将此临时数组的内容复制到目标数组的 destPosdestPos+length-1 位置一样。

If 如果 destnull,则抛出 NullPointerException 异常。

如果 srcnull, 则抛出 NullPointerException 异常,并且不会修改目标数组。

否则,只要下列任何情况为真,则抛出 ArrayStoreException 异常并且不会修改目标数组:

  • src 参数指的是非数组对象。
  • dest 参数指的是非数组对象。
  • src 参数和 dest 参数指的是那些其组件类型为不同基本类型的数组。
  • src 参数指的是具有基本组件类型的数组且 dest 参数指的是具有引用组件类型的数组。
  • src 参数指的是具有引用组件类型的数组且 dest 参数指的是具有基本组件类型的数组。

否则,只要下列任何情况为真,则抛出 IndexOutOfBoundsException 异常,并且不会修改目标数组:

  • srcPos 参数为负。
  • destPos 参数为负。
  • length 参数为负。
  • srcPos+length 大于 src.length,即源数组的长度。
  • destPos+length 大于 dest.length,即目标数组的长度。

否则,如果源数组中 srcPossrcPos+length-1 位置上的实际组件通过分配转换并不能转换成目标数组的组件类型,则抛出 ArrayStoreException 异常。在这种情况下,将 k 设置为比长度小的最小非负整数,这样就无法将 src[srcPos+k] 转换为目标数组的组件类型;当抛出异常时,从 srcPossrcPos+k-1 位置上的源数组组件已经被复制到目标数组中的 destPosdestPos+k-1 位置,而目标数组中的其他位置不会被修改。(因为已经详细说明过的那些限制,只能将此段落有效地应用于两个数组都有引用类型的组件类型的情况。)

 

参数:
src - 源数组。
srcPos - 源数组中的起始位置。
dest - 目标数组。
destPos - 目标数据中的起始位置。
length - 要复制的数组元素的数量。
抛出:
IndexOutOfBoundsException - 如果复制会导致对数组范围以外的数据的访问。
ArrayStoreException - 如果因为类型不匹配而使得无法将 src 数组中的元素存储到 dest 数组中。
NullPointerException - 如果 srcdestnull

package com.hengeasy.gris.dao.impl

public   class  CopyArray  {

   
public static void main(String[] args) {
       
int elements[] = 123456 };
       
int hold[] = 10987654321 };
       
       
int result[] = new int[16];
       
       
//数组累加
        System.arraycopy(elements, 0, result, 0, elements.length);
        System.arraycopy(hold, 
0, result, elements.length, hold.length);        
       
for (int i = 0; i < result.length; i++)
            System.out.println(
"result[" + i + "]=" + result[i]);
       
       
//自复制
        System.arraycopy(elements, 0, elements, 0, elements.length);
           for (int i = 0; i < elements.length; i++)
               System.out.println("elements[" + i + "]=" + elements[i]);

       
//覆盖累加
        System.arraycopy(elements, 0, hold, 0, elements.length);        
       
for (int i = 0; i < hold.length; i++)
            System.out.println(
"hold[" + i + "]=" + hold[i]);
     }

}

传感器位置(Sensor Position)是指在移动设备中,用于确定设备在空间中的位置和方向的传感器。其中包括加速度计、陀螺仪、磁力计等。这些传感器可以帮助应用程序确定设备的方向、位置和移动情况,从而提供更好的用户体验。 Android系统提供了一组API,用于访问传感器数据。开发人员可以使用这些API来获取传感器数据,并根据需要对其进行处理。以下是使用传感器API获取设备方向的示例代码: ```java public class MainActivity extends AppCompatActivity implements SensorEventListener { private SensorManager sensorManager; private Sensor accelerometer; private Sensor magnetometer; private float[] accelerometerReading = new float[3]; private float[] magnetometerReading = new float[3]; private float[] rotationMatrix = new float[9]; private float[] orientationAngles = new float[3]; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); sensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE); accelerometer = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER); magnetometer = sensorManager.getDefaultSensor(Sensor.TYPE_MAGNETIC_FIELD); } @Override protected void onResume() { super.onResume(); sensorManager.registerListener(this, accelerometer, SensorManager.SENSOR_DELAY_NORMAL); sensorManager.registerListener(this, magnetometer, SensorManager.SENSOR_DELAY_NORMAL); } @Override protected void onPause() { super.onPause(); sensorManager.unregisterListener(this); } @Override public void onSensorChanged(SensorEvent event) { if (event.sensor == accelerometer) { System.arraycopy(event.values, 0, accelerometerReading, 0, accelerometerReading.length); } else if (event.sensor == magnetometer) { System.arraycopy(event.values, 0, magnetometerReading, 0, magnetometerReading.length); } updateOrientationAngles(); } @Override public void onAccuracyChanged(Sensor sensor, int accuracy) { // do nothing } private void updateOrientationAngles() { SensorManager.getRotationMatrix(rotationMatrix, null, accelerometerReading, magnetometerReading); SensorManager.getOrientation(rotationMatrix, orientationAngles); // Convert radians to degrees float azimuthDegrees = (float) Math.toDegrees(orientationAngles[0]); float pitchDegrees = (float) Math.toDegrees(orientationAngles[1]); float rollDegrees = (float) Math.toDegrees(orientationAngles[2]); Log.d("MainActivity", "Azimuth: " + azimuthDegrees + ", Pitch: " + pitchDegrees + ", Roll: " + rollDegrees); } } ``` 该示例代码使用加速度计和磁力计传感器获取设备的方向,并将其转换为方位角度。开发人员可以根据需要修改代码,以满足其特定的应用程序需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值