Java—数组添加元素

本文详细介绍了如何使用Java的Arrays.sort()方法对数组进行排序,并通过insertElement()自定义方法在指定位置插入元素,展示了数组操作的基本技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java—数组添加元素

[java] view plaincopyprint?

  1. 以下实例演示了如何使用sort()方法对Java数组进行排序,及如何使用 insertElement () 方法向数组插入元素  

[java] view plaincopyprint?

  1. /* 
  2.      * 数组添加元素 
  3.      * */  
  4.     public static void main(String[] args) {  
  5.         int array[] ={ 2, 5, -2, 6, -3, 8, 0, -7, -9, 4};  
  6.         Arrays.sort(array);  
  7.           
  8.         printArray("数组排序:", array);  
  9.           
  10.         int index=Arrays.binarySearch(array, 3);  
  11.           
  12.         System.out.println("元素 3 所在位置(负数不存在):"+index);  
  13.           
  14.         int newIndex=-index-1;  
  15.           
  16.         array=insertElement(array, 3, newIndex);  
  17.           
  18.         printArray("数组添加元素 3:", array);  
  19.     }  
  20.     private static void printArray(String message,int array[]){  
  21.         System.out.println(message+"[length:"+array.length+"]");  
  22.         for (int i = 0; i < array.length; i++) {  
  23.             if (i!=0) {  
  24.                 System.out.print(",");  
  25.             }  
  26.             System.out.print(array[i]);  
  27.         }  
  28.         System.out.println();  
  29.     }  
  30.     private static int[] insertElement(int original[],int element,int index){  
  31.           
  32.         int length=original.length;  
  33.           
  34.         int destination[]=new int[length+1];  
  35.           
  36.         System.arraycopy(original, 0, destination, 0, index);  
  37.           
  38.         destination[index]=element;  
  39.           
  40.         System.arraycopy(original, index, destination, index+1, length-index);  
  41.           
  42.         return destination;  
  43.     }  
  44.       

System提供了一个静态方法arraycopy(),我们可以使用它来实现数组之间的复制。

其函数原型是: public static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length)

 src:源数组; srcPos:源数组要复制的起始位置; dest:目的数组; destPos:目的数组放置的起始位置; length:复制的长度。 

注意:src and dest都必须是同类型或者可以进行转换类型的数组. 有趣的是这个函数可以实现自己到自己复制,比如: int[] fun ={0,1,2,3,4,5,6}; System.arraycopy(fun,0,fun,3,3); 则结果为:{0,1,2,0,1,2,6}; 实现过程是这样的,先生成一个长度为length的临时数组,将fun数组中srcPos 到srcPos+length-1之间的数据拷贝到临时数组中,再执行System.arraycopy(临时数组,0,fun,3,3).

### 向Java数组添加元素Java中,一旦定义了一个固定大小的数组,则无法改变其长度。因此,“向数组添加元素”的概念并不适用于传统意义上的数组操作;如果需要动态增集合中的元素数量,通常会建议使用`ArrayList`类[^1]。 然而,在某些情况下确实可能希望模拟这种行为——比如通过创建一个新的更大容量的数组并将原有数据复制过去来实现所谓的“扩展”。下面给出一段简单的代码示例用于演示如何模仿这一过程: ```java public class Main { public static void main(String[] args) { // 初始化原始整型数组 Integer[] originalArray = new Integer[]{1, 2, 3}; // 打印原数组内容 System.out.println("Original Array:"); printArray(originalArray); // 添加元素数组 Integer elementToAdd = 4; Integer[] newArray = addElementToArray(originalArray, elementToAdd); // 输出更新后的数组 System.out.println("\nUpdated Array after adding " + elementToAdd + ":"); printArray(newArray); } private static <T> T[] addElementToArray(T[] oldArray, T element){ final List<T> tempList = Arrays.asList(oldArray); final List<T> newList = new ArrayList<>(tempList){{ add(element); }}; @SuppressWarnings("unchecked") T[] resultArray = (T[])newList.toArray((T[]) java.lang.reflect.Array.newInstance(oldArray.getClass().getComponentType(), newSize)); return resultArray; } private static void printArray(Integer[] arr){ for(int i : arr){ System.out.print(i+" "); } } } ``` 上述程序展示了怎样利用泛型方法`addElementToArray()`接收任意类型的旧数组以及待入的新项作为参数,并返回含有新增成员的新数组实例。注意这里为了简化处理采用了反射机制生成适当类型的结果集。 对于频繁执行增删改查的应用场景而言,推荐采用更灵活的数据结构如`ArrayList`而非基本数组,因为前者提供了更为便捷的方法来进行这些操作而无需手动管理底层存储空间的变化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值