聊聊 Java 集合框架中的Arrays

这篇具有很好参考价值的文章主要介绍了聊聊 Java 集合框架中的Arrays。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

一、Arrays 类概述

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

java.lang.Objectjava.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 类常用方法解析文章来源地址https://www.toymoban.com/news/detail-811655.html

到了这里,关于聊聊 Java 集合框架中的Arrays的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据结构】搜索树 与 Java集合框架中的Set,Map

    作者主页:paper jie_博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文录入于《JAVA数据结构》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将javaSE基础知识一网打尽,希望可以帮到读者们哦。 其他专栏:《

    2024年02月08日
    浏览(38)
  • 【JavaSE】Java基础语法(十三):Java 中的集合(十分全面)

    List (对付顺序的好帮⼿): 存储的元素是有序的、可重复的。 Set (注重独⼀⽆⼆的性质): 存储的元素是⽆序的、不可重复的。 Queue (实现排队功能的叫号机): 按特定的排队规则来确定先后顺序,存储的元素是有序的、可重复的。 Map (⽤ key 来搜索的专家): 使⽤键值对(key-value)存

    2024年02月10日
    浏览(42)
  • Java开发基础系列(十三):集合对象(Set接口)

    😊 @ 作者: 一恍过去 💖 @ 主页: https://blog.csdn.net/zhuocailing3390 🎊 @ 社区: Java技术栈交流 🎉 @ 主题: Java开发基础系列(十三):集合对象(Set接口) ⏱️ @ 创作时间: 2023年07月27日 HashSet: 基于哈希表实现的集合,不保证元素的顺序。 LinkedHashSet: 基于哈希表和双向链表实现的

    2024年02月15日
    浏览(36)
  • java中的Arrays.sort()排序方法

    目录 一、方法重载 二、注意事项  三、举例 (1)对于基本数据类型的数组,排序时会按照升序排序; (2)对对象数组进行排序 Java中的 Arrays.sort() 方法是一种内置的排序方法,用于对数组进行排序。这是一个来自 java.util.Arrays 类的静态方法,用于对所有的基本数据类型对

    2024年02月08日
    浏览(55)
  • [java][集合相关—整理1][面试题]java集合框架大厂面试题整理

    Java中集合框架提供了大量的集合类:常见的list ,set, map等 几个相关的大厂面试题:

    2024年04月08日
    浏览(47)
  • com.google.common.collect 是 Google Guava 库中的一个包,它提供了一系列扩展和增强 Java 集合框架的工具类和数据结构

    com.google.common.collect 是 Google Guava 库中的一个包,它提供了一系列扩展和增强 Java 集合框架的工具类和数据结构。Guava 的集合工具在设计上强调性能、不可变性、功能性和易用性。 以下是 com.google.common.collect 包中一些重要的类和接口: Immutable Collections: ImmutableSet:一个不可变

    2024年03月19日
    浏览(61)
  • Java 集合框架2

    一、关于set接口的常用类         1.HashSet类            用来处理无序的单列数据,没有重复的元素,重复的元素算一个            i.构造方法           ii.实例方法         2.LinkedHashSet类            LikedHashSet类是HashSet类的子类             i.构造方法:            

    2024年02月11日
    浏览(37)
  • Java 集合框架体系简介

    存储多个数据可以使用数组,但由于数组在内存中是连续存储的,所以会有一些限制。比如数组在创建时就要指定长度,即可以容纳的元素个数,且指定后无法更改;数组在创建时需要指定元素的类型,并且所有元素都必须是该类型或其子类;添加或删除数组中的元素需要创

    2024年02月08日
    浏览(48)
  • Java集合框架

    Java集合类主要由两个根接口Collection和Map派生出来的。 Collection派生出了三个子接口: 1)List List代表了有序可重复集合,可直接根据元素的索引来访问 2)Set Set代表无序不可重复集合,只能根据元素本身来访问 3)Queue Queue是队列集合 Map接口派生: Map代表的是存储 key-value对的集合

    2024年02月01日
    浏览(56)
  • 探索Java集合框架—数据结构、ArrayList集合

    Java集合的使用相信大家都已经非常得心应手,但是我们怎么做到知其然,更知其所以然这种出神入化的境界呢?我们揭开集合框架底层神秘面纱来一探究竟 目录 一、背景介绍 二、思路方案 数据结构是什么? 数据结构可以分为线性和非线性两种数据结构 线性数据结构: 非

    2024年02月10日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包