今天突然思考一个问题,数组的增删改查我好像还没实现过,于是就利用System.arraycopy简单的实现了一下:
/** * 实现数组的增加元素操作 * @param array 目标数组 * @param number 增加的元素 * @param index 要添加的位置索引 * @return 增加元素后的新数组 */ public int[] create(int[] array,int number,int index){ int[] newArray = new int[array.length+1]; System.arraycopy(array,0,newArray,0,index); newArray[index] = number; System.arraycopy(array, index, newArray, index+1, array.length-index); return newArray; }
/** * 实现数组的delete操作 * @param array 目标数组 * @param index 索引位置 * @return 删除后的新数组 */ public int[] delete(int[] array,int index){ int[] newArray = new int[array.length-1]; System.arraycopy(array, 0, newArray, 0, index); System.arraycopy(array, index+1, newArray, index, array.length-index-1); return newArray; }
/** * 判断数组中是否含有该元素 * @param array 目标数组 * @param number 目标元素 * @return 含有该元素的个数 */ public int retrieve(int[] array,int number){ int index = 0; for(int i : array){ if(i==number) index++; } return index; }
为了简单我直接用int数组来实现,可以换成Object。