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 类提供了很多便捷的方法,可以方便地操作数组,并且这些方法都是静态的,可以直接通过类名调用。

相关推荐
A阳俊yi15 分钟前
Spring Data JPA
java·开发语言
小王不爱笑13218 分钟前
Spring AOP(AOP+JDBC 模板 + 转账案例)
java·后端·spring
遇印记25 分钟前
蓝桥java蜗牛
java·学习·蓝桥杯
m0_5656111344 分钟前
Java-泛型
java·windows
张np1 小时前
java基础-集合接口(Collection)
java·开发语言
jakeswang1 小时前
ServletLess架构简介
java·后端·servletless
搬山境KL攻城狮1 小时前
maven 私服上传jar
java·maven·jar
q***56382 小时前
Spring Boot--@PathVariable、@RequestParam、@RequestBody
java·spring boot·后端
FREE技术2 小时前
学生成绩管理系统 基于java+springboot+vue实现前后端分离项目并附带万字文档(源码+数据库+万字详设文档+软件包+安装教程)
java·vue.js·spring boot·mysql
她说人狗殊途2 小时前
时间复杂度(按增长速度从低到高排序)包括以下几类,用于描述算法执行时间随输入规模 n 增长的变化趋势:
数据结构·算法·排序算法