Java——Arrays常用方法

Arrays常用方法

Java 中的 Arrays 类提供了一系列静态方法,可以用来操作数组。

1. sort() 方法------默认升序排序

Arrays.sort() 方法用于对数组进行排序。该方法有多个重载版本,可以对不同类型的数组进行排序。

java 复制代码
public static void sort(int[] arr)
public static void sort(int[] arr, int fromIndex, int toIndex)
public static void sort(Object[] arr)
public static void sort(Object[] arr, int fromIndex, int toIndex)

参数说明:

  • arr:要排序的数组。
  • fromIndex:排序的起始位置(包含)。
  • toIndex:排序的结束位置(不包含)

例如:

java 复制代码
int[] arr = {5, 2, 1, 6, 3, 4};
Arrays.sort(arr); // 默认升序排序
System.out.println(Arrays.toString(arr)); // [1, 2, 3, 4, 5, 6]
=============================================================================
int[] arr = {5, 2, 1, 6, 3, 4};
Arrays.sort(arr, 1, 5);
System.out.println(Arrays.toString(arr)); // [5, 1, 2, 3, 6, 4]

2. binarySearch() 方法(二分查找)

Arrays.binarySearch() 方法用于在已排序的数组中查找指定元素。该方法有多个重载版本,可以对不同类型的数组进行查找。

java 复制代码
public static int binarySearch(int[] arr, int key)
public static int binarySearch(int[] arr, int fromIndex, int toIndex, int key)
public static int binarySearch(Object[] arr, Object key)
public static int binarySearch(Object[] arr, int fromIndex, int toIndex, Object key)

参数说明:

  • arr:要查找的数组,必须已经排好序。
  • fromIndex:查找的起始位置(包含)。
  • toIndex:查找的结束位置(不包含)。
  • key:要查找的元素。

返回值:

  • 如果查找到了指定元素,则返回该元素在数组中的索引(从 0 开始)。
  • 如果未查找到指定元素,则返回一个负数,表示应该插入该元素的位置(以维持数组的有序性)。

例如:

java 复制代码
int[] arr = {1, 2, 3, 4, 5, 6};
int index = Arrays.binarySearch(arr, 3);
System.out.println(index); // 2
==========================================================================
String[] arr = {"apple", "banana", "cherry", "date", "elderberry"};
int index = Arrays.binarySearch(arr, 1, 4, "cherry");
System.out.println(index); // 2

3. fill() 方法

Arrays.fill() 方法用于将数组的所有元素赋为指定的值。

java 复制代码
public static void fill(int[] arr, int value)
public static void fill(int[] arr, int fromIndex, int toIndex, int value)
public static void fill(Object[] arr, Object value)
public static void fill(Object[] arr, int fromIndex, int toIndex, Object value)

参数说明:

  • arr:要填充的数组。
  • fromIndex:填充的起始位置(包含)。
  • toIndex:填充的结束位置(不包含)
  • value:要填充的值。

例如:

java 复制代码
int[] arr = new int[5];
Arrays.fill(arr, 1);
System.out.println(Arrays.toString(arr)); // [1, 1, 1, 1, 1]
===========================================================================
char[] arr = new char[5];
Arrays.fill(arr, 1, 4, 'A');
System.out.println(Arrays.toString(arr)); // [0, A, A, A, 0]

4. copyOf() 方法

Arrays.copyOf() 方法用于复制数组的一部分。如果复制的长度比原数组长,则用默认值填充新的位置。

java 复制代码
public static int[] copyOf(int[] original, int newLength)
public static <T> T[] copyOf(T[] original, int newLength)

参数说明:

  • original:要复制的数组。
  • newLength:复制的长度。

返回值:新的数组,内容为原数组的一部分。

例如:

java 复制代码
int[] arr1 = {1, 2, 3, 4, 5};
int[] arr2 = Arrays.copyOf(arr1, 3);
System.out.println(Arrays.toString(arr2)); // [1, 2, 3]
==========================================================================
String[] arr1 = {"apple", "banana", "cherry"};
String[] arr2 = Arrays.copyOf(arr1, 5);
System.out.println(Arrays.toString(arr2)); // [apple, banana, cherry, null, null]

5. equals() 方法

Arrays.equals() 方法用于比较两个数组是否相等。

java 复制代码
public static boolean equals(int[] a, int[] b)
public static boolean equals(Object[] a, Object[] b)

参数说明:

  • a、b:要比较的两个数组。

返回值:如果两个数组长度相等且对应位置的元素都相等,则返回 true,否则返回 false。

例如:

java 复制代码
int[] arr1 = {1, 2, 3};
int[] arr2 = {1, 2, 3};
System.out.println(Arrays.equals(arr1, arr2)); // true

6. toString() 方法

Arrays.toString() 方法用于将数组转换成字符串形式。

java 复制代码
public static String toString(int[] arr)
public static String toString(Object[] arr)

参数说明:

  • arr:要转换的数组。

返回值:转换后的字符串,格式为 [element1, element2, ..., elementN]。

例如:

java 复制代码
int[] arr = {1, 2, 3};
System.out.println(Arrays.toString(arr)); // [1, 2, 3]

Arrays 类提供了很多便捷的方法,可以方便地操作数组,并且这些方法都是静态的,可以直接通过类名调用。

相关推荐
用户40315986396632 分钟前
简易二进制编辑器
java·算法
bin91535 分钟前
飞算 JavaAI:开启 Java 开发新时代
java·人工智能
起个数先6 分钟前
快速排序算法(Java)
数据结构·排序算法
Tim_1013 分钟前
【算法专题训练】02、二进制
java·开发语言·算法
Code季风17 分钟前
Spring Bean的生命周期详解
java·spring boot·spring
清风920024 分钟前
Logback——日志技术(基础)
java·前端·logback
EndingCoder24 分钟前
排序算法与前端交互优化
开发语言·前端·javascript·算法·排序算法·交互
晓131326 分钟前
JavaScript加强篇——第五章 DOM节点(加强)与BOM
java·开发语言·javascript
程序猿零零漆32 分钟前
飞算JavaAI:革新Java开发的智能助手
java·飞算javaai
万能小锦鲤44 分钟前
《Java EE与中间件》实验三 基于Spring Boot框架的购物车
java·spring boot·mysql·实验报告·购物车·文档资源·java ee与中间件