聊聊Java集合框架中的Arrays类

简介: ``Arrays`` 和 ``Collections``是分别操作数组和集合的两个工具类。今天就来对 ``Arrays`` 中的内容作个总结。

ArraysCollections是分别操作数组和集合的两个工具类。今天就来对 Arrays 中的内容作个总结。

一、Arrays 类概述

Arrays 类位于 java.util包中。Arrays 继承 Object

java.lang.Object
 ↳ java.util.Arrays

Arrays 类中的静态方法可以对数组进行排序、查询、搜索等等操作。

二、Arrays 类中方法

1. Arrays.asList()

方法描述

该方法返回一个 ArrayList , 其返回的 ArrayList 从下面的代码可以看出不是我们平常 new 出来的动态可扩展的 ArrayList。可以看这篇 ArrayList

@SafeVarargs
@SuppressWarnings("varargs")
public static <T> List<T> asList(T... a) {
   
    return new ArrayList<>(a);
}

/**
     * @serial include
     */
private static class ArrayList<E> extends AbstractList<E>
    implements RandomAccess, java.io.Serializable
{
   
    private static final long serialVersionUID = -2764017481108945198L;
    private final E[] a;

    ArrayList(E[] array) {
   
        a = Objects.requireNonNull(array);
    }

    @Override
    public int size() {
   
        return a.length;
    }

    @Override
    public Object[] toArray() {
   
        return a.clone();
    }

    @Override
    @SuppressWarnings("unchecked")
    public <T> T[] toArray(T[] a) {
   
        int size = size();
        if (a.length < size)
            return Arrays.copyOf(this.a, size,
                                 (Class<? extends T[]>) a.getClass());
        System.arraycopy(this.a, 0, a, 0, size);
        if (a.length > size)
            a[size] = null;
        return a;
    }

    @Override
    public E get(int index) {
   
        return a[index];
    }

    @Override
    public E set(int index, E element) {
   
        E oldValue = a[index];
        a[index] = element;
        return oldValue;
    }

    @Override
    public int indexOf(Object o) {
   
        E[] a = this.a;
        if (o == null) {
   
            for (int i = 0; i < a.length; i++)
                if (a[i] == null)
                    return i;
        } else {
   
            for (int i = 0; i < a.length; i++)
                if (o.equals(a[i]))
                    return i;
        }
        return -1;
    }

    @Override
    public boolean contains(Object o) {
   
        return indexOf(o) != -1;
    }

    @Override
    public Spliterator<E> spliterator() {
   
        return Spliterators.spliterator(a, Spliterator.ORDERED);
    }

    @Override
    public void forEach(Consumer<? super E> action) {
   
        Objects.requireNonNull(action);
        for (E e : a) {
   
            action.accept(e);
        }
    }

    @Override
    public void replaceAll(UnaryOperator<E> operator) {
   
        Objects.requireNonNull(operator);
        E[] a = this.a;
        for (int i = 0; i < a.length; i++) {
   
            a[i] = operator.apply(a[i]);
        }
    }

    @Override
    public void sort(Comparator<? super E> c) {
   
        Arrays.sort(a, c);
    }
}

来个例子

public static void main(String[] args) {
   
    //创建一个数组
    int[] a = {
   1,2,3};
    //new 一个 ArrayList
    ArrayList<Integer> list = new ArrayList<>();
    list.add(1);
    list.add(2);
    list.add(3);


    System.out.println(list);//[1, 2, 3]

    System.out.println(a); //[I@1540e19d
    System.out.println(Arrays.toString(a));//[1, 2, 3]

    /*如果将基本数据类型的数组作为参数传入,该方法会把整个数组当成一个元素*/
    System.out.println(Arrays.asList(a));//[[I@1540e19d] 
    System.out.println(Arrays.asList(1,2,3));//[1, 2, 3]
}

2. Arrays.sort(originalArray)

方法描述

对数组所有元素进行升序排序,没有返回值。

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
Arrays.sort(a);
System.out.println(Arrays.toString(a));//[1, 2, 3, 4, 5, 6, 7, 8, 9]

3. Arrays.sort(originalArray, fromIndex, endIndex)

方法描述

对数组特定序列进行升序排序,从 [fromIndex, endIndex]区域的数组元素进行排序

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
Arrays.sort(a,0,5);
System.out.println(Arrays.toString(a));//[1, 2, 3, 4, 9, 5, 6, 7, 8]

4. Arrays.sort(T[] a, Comparator<super T> c )

方法描述

利用自定义的比较器,来对数组元素进行排序

来个例子


// Java program to demonstrate working of Comparator
// interface
import java.util.*;
import java.lang.*;
import java.io.*;

// A class to represent a student.
class Student {
   
    int rollno;
    String name, address;

    // Constructor
    public Student(int rollno, String name,
                   String address)
    {
   
        this.rollno = rollno;
        this.name = name;
        this.address = address;
    }

    // Used to print student details in main()
    public String toString()
    {
   
        return this.rollno + " "
            + this.name + " "
            + this.address;
    }
}
//自定义的比较器,对两个对象的 rollno 属性进行比较
class Sortbyroll implements Comparator<Student> {
   
    // Used for sorting in ascending order of
    // roll number
    public int compare(Student a, Student b)
    {
   
        return a.rollno - b.rollno;
    }
}

// Driver class
class Main {
   
    public static void main(String[] args)
    {
   
        Student[] arr = {
    new Student(1, "bbbb", "london"),
                         new Student(3, "aaaa", "nyc"),
                         new Student(2, "cccc", "jaipur") };

        System.out.println("Unsorted-未排序前");
        for (int i = 0; i < arr.length; i++)
            System.out.println(arr[i]);

        Arrays.sort(arr, new Sortbyroll());

        System.out.println("\nSorted by rollno-排序后");
        for (int i = 0; i < arr.length; i++)
            System.out.println(arr[i]);
    }
}
/** 输出结果:
*Unsorted-未排序前
*1 bbbb london
*3 aaaa nyc
*2 cccc jaipur
*
*Sorted by rollno-排序后
*1 bbbb london
*2 cccc jaipur
*3 aaaa nyc
*
**/

5. Arrays.sort(T[] a, int fromIndex, int toIndex, Comparator<super T> c)

方法描述

利用自定义的比较器,来对数组中指定范围元素进行排序

来个例子

把4中代码换成

Arrays.sort(arr, 1, 2, new Sortbyroll());//对第一、二个元素进行比较
/** 输出结果:
*Unsorted-未排序前
*1 bbbb london
*3 aaaa nyc
*2 cccc jaipur
*
*Sorted by rollno-排序后
*1 bbbb london
*3 aaaa nyc
*2 cccc jaipur
*
**/

6. Arrays.parallelSort(originalArray)

方法描述

对数组元素进行升序排序,当数据规模较大时,性能更好(并行排序)。

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
Arrays.parallelSort(a);
System.out.println(Arrays.toString(a));//[1, 2, 3, 4, 9, 5, 6, 7, 8]

7.Arrays.fill(originalArray, fillValue)Arrays.fill(originalArray, intfromIndex, int toIndex, fillValue)

方法描述

用 fillValue 值来填充数组。前一个函数填充所有,后面的函数填充指定范围。

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
Arrays.fill(a,1);//[1, 1, 1, 1, 1, 1, 1, 1, 1]
Arrays.fill(a,1,3,1);//[1, 1, 1, 9, 4, 5, 6, 7, 8]

8.Arrays.equals(array1, array2)Arrays.deepEquals(array1, array2)

方法描述

判断两个数组是否相等, 返回布尔值

equals()主要针对基本数据和Object 一维数组,其比较规则如下:

if (a==a2)
    return true;
if (a==null || a2==null)
    return false;

int length = a.length;
if (a2.length != length)
    return false;

for (int i=0; i<length; i++) {
   
    Object o1 = a[i];
    Object o2 = a2[i];
    if (!(o1==null ? o2==null : o1.equals(o2)))
        return false;
}

return true;

deepEquals()主要是多维数组的比较,其比较规则为:

if (a1 == a2)
    return true;
if (a1 == null || a2==null)
    return false;
int length = a1.length;
if (a2.length != length)
    return false;

for (int i = 0; i < length; i++) {
   
    Object e1 = a1[i];
    Object e2 = a2[i];

    if (e1 == e2)
        continue;
    if (e1 == null)
        return false;

    // Figure out whether the two elements are equal
    boolean eq = deepEquals0(e1, e2);

    if (!eq)
        return false;
}

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
int[] b = {
   1,2};
int[][] c = {
   {
   1,2},{
   1,3}};
int[][] d = {
   {
   1,2},{
   1,3}};
Arrays.equals(a,b);//false
Arrays.equals(c,d);//true

9.Arrays.hashCode(originalArray)Arrays.deepHashCode(originalArray)

方法描述

返回该数组的哈希值

前面一个函数是返回一维数组,后面是多维数组

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
int[][] c = {
   {
   1,2},{
   1,3}};
System.out.println(Arrays.hashCode(a));//887857437
System.out.println(Arrays.deepHashCode(c));//31776

10.Arrays.binarySearch(originalArray, key)Arrays.binarySearch(originalArray,fromIndex,toIndex,key,Comparator)

方法描述

方法一:在数组中对某值进行二分查找(注意要先对数组排序!),如果存在返回其下标,否则返回 -(数组极值下标 +1)。

方法二:方法中的参数限定数组的范围,Comparator 是自定义的比较器

来个例子

int[] a = {
   1,2,3,4,5,9,6,7,8};
Arrays.sort(a);
System.out.println(Arrays.binarySearch(a,1));//0
System.out.println(Arrays.binarySearch(a,0));//-1
System.out.println(Arrays.binarySearch(a,10));//-10

11.Arrays.copyOf(originalArray, newLength)Arrays.copyOfRange(originalArray,fromIndex,endIndex)

方法描述

方法一:拷贝数组,newLength 是拷贝的长度,如果超过原数组的长度,则用 null 进行填充。并返回一个新数组。

方法二:拷贝数组,fromIndex 和 endIndex 是数组的范围下标。并返回一个新数组。

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
System.out.println(Arrays.toString(Arrays.copyOf(a,3)));//[1,2,3]
System.out.println(Arrays.toString(Arrays.copyOfRange(a,0,3)));//[1,2,3]

13.Arrays.toString(originalArray)Arrays.deepToString(originalArray)

方法描述

返回数组元素的字符串形式,方法一是一维数组,方法二是多维数组。

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
System.out.println(Arrays.toString(a));//[1,2,3,9,4,5,6,7,8]
int[][] c = {
   {
   1,2},{
   3}};
System.out.println(Arrays.deepToString(c));//[[1, 2], [3]]

14.Arrays.setAll(originalArray,functionalGenerator)Arrays.parallelSetAll(originalArray, functionalGenerator)

方法描述

方法一:将数组中的所有元素,串行的使用方法提供的生成器函数来计算每个元素(一元操作)

方法二:将数组中的所有元素,串行的使用方法提供的生成器来计算每个元素(一元操作)适用于大规模数据

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
Arrays.setAll(a, i -> a[i] * 2);
System.out.println(Arrays.toString(a));//[2,4,6,18,8,10,12,14,16]

Arrays.parallelSetAll(a, i  -> a[i] * 2);
System.out.println(Arrays.toString(a));//[2,4,6,18,8,10,12,14,16]

15. Arrays.parallelPrefix(originalArray, BinaryOperator op)Arrays.parallelPrefix(originalArray, int fromIndex, int toIndex, BinaryOperator op)

方法描述

方法一:将数组中所有元素,并行使用生成器函数来计算每个元素(二元操作)

方法二:将数组中部分序列元素,并行使用生成器函数来计算每个元素(二元操作)

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
Arrays.parallelPrefix(a, (x,y) -> x*y);//依次累乘
System.out.println(Arrays.toString(a));//[1, 2, 6, 54, 216, 1080, 6480, 45360, 362880]

Arrays.parallelPrefix(a, 0, 3, (x,y) -> x*y);//依次累乘
System.out.println(Arrays.toString(a));//[1, 2, 6, 9, 4, 5, 6, 7, 8]

16.Arrays.spliterator(originalArray)Arrays.spliterator(originalArray,fromIndex,endIndex)

方法描述

返回数组的分片迭代器,用于并行的遍历数组

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
Spliterator<Integer> s = Arrays.spliterator(a);
s.forEachRemaining(System.out::println);
/**
*
*1
*2
*3
*9
*4
*5
*6
*7
*8
**/

17.Arrays.stream(originalArray)

方法描述

返回数组的流,可以对数组使用 Stream 相关的方法。

来个例子

int[] a = {
   1,2,3,9,4,5,6,7,8};
List<Integer> list = Arrays.stream(a).collect(toList());
System.out.println(list);//[1,2,3,9,4,5,6,7,]

三、参考资料

Arrays class in Java

Java Collections - Arrays.spliterator() Example

Arrays 类常用方法解析

目录
相关文章
|
1月前
|
安全 前端开发 Java
《深入理解Spring》:现代Java开发的核心框架
Spring自2003年诞生以来,已成为Java企业级开发的基石,凭借IoC、AOP、声明式编程等核心特性,极大简化了开发复杂度。本系列将深入解析Spring框架核心原理及Spring Boot、Cloud、Security等生态组件,助力开发者构建高效、可扩展的应用体系。(238字)
|
1月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
86 4
|
1月前
|
IDE JavaScript Java
在Java 11中,如何处理被弃用的类或接口?
在Java 11中,如何处理被弃用的类或接口?
158 5
|
1月前
|
存储 安全 Java
《数据之美》:Java集合框架全景解析
Java集合框架是数据管理的核心工具,涵盖List、Set、Map等体系,提供丰富接口与实现类,支持高效的数据操作与算法处理。
|
1月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
142 1
|
1月前
|
Java Go 开发工具
【Java】(8)正则表达式的使用与常用类分享
正则表达式定义了字符串的模式。正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别。
203 1
|
1月前
|
存储 Java 程序员
【Java】(6)全方面带你了解Java里的日期与时间内容,介绍 Calendar、GregorianCalendar、Date类
java.util 包提供了 Date 类来封装当前的日期和时间。Date 类提供两个构造函数来实例化 Date 对象。第一个构造函数使用当前日期和时间来初始化对象。Date( )第二个构造函数接收一个参数,该参数是从1970年1月1日起的毫秒数。
146 1
|
Java 开发者
奇迹时刻!探索 Java 多线程的奇幻之旅:Thread 类和 Runnable 接口的惊人对决
【8月更文挑战第13天】Java的多线程特性能显著提升程序性能与响应性。本文通过示例代码详细解析了两种核心实现方式:Thread类与Runnable接口。Thread类适用于简单场景,直接定义线程行为;Runnable接口则更适合复杂的项目结构,尤其在需要继承其他类时,能保持代码的清晰与模块化。理解两者差异有助于开发者在实际应用中做出合理选择,构建高效稳定的多线程程序。
182 7
|
Java 开发者
在 Java 中,一个类可以实现多个接口吗?
这是 Java 面向对象编程的一个重要特性,它提供了极大的灵活性和扩展性。
577 58
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
242 3
下一篇
oss云网关配置