聊聊 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);}@Overridepublic int size() {return a.length;}@Overridepublic 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;}@Overridepublic E get(int index) {return a[index];}@Overridepublic E set(int index, E element) {E oldValue = a[index];a[index] = element;return oldValue;}@Overridepublic 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;}@Overridepublic boolean contains(Object o) {return indexOf(o) != -1;}@Overridepublic Spliterator<E> spliterator() {return Spliterators.spliterator(a, Spliterator.ORDERED);}@Overridepublic void forEach(Consumer<? super E> action) {Objects.requireNonNull(action);for (E e : a) {action.accept(e);}}@Overridepublic 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]);}}@Overridepublic void sort(Comparator<? super E> c) {Arrays.sort(a, c);}
}
来个例子
public static void main(String[] args) {//创建一个数组int[] a = {1,2,3};//new 一个 ArrayListArrayList<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@1540e19dSystem.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;// Constructorpublic 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 numberpublic 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 equalboolean 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 类常用方法解析

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/610995.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Zookeeper设计理念与源码剖析

Zookeeper 架构理解 整体架构 Follower server 可以直接处理读请求&#xff0c;但不能直接处理写请求。写请求只能转发给 leader server 进行处理。最终所有的写请求在 leader server 端串行执行。&#xff08;因为分布式环境下永远无法精确地确认不同服务器不同事件发生的先后…

easyExcel 获取多个sheet中复杂表头的数据

easyExcel 获取多个sheet中复杂表头的数据 easyExcel 解释 EasyExcel是一个强大且易于使用的Java库&#xff0c;用于简化Excel文件的读写操作。它是阿里巴巴开源的一个基于POI实现的Excel处理工具&#xff0c;并提供了一组简单的API来处理Excel文件&#xff0c;包括读取、写入…

逐步分解,一文教会你如何用 jenkins+docker 实现主从模式

jenkins 主从模式想必大家都不陌生&#xff0c;大家在学习过程中为了学习方便都在自己本地搭建了 jenkins 环境&#xff0c;然后通过 javaweb 方式实现&#xff0c;对于 docker 下实现主从模式大家好像兴趣挺大。 今天就通过这篇文章给大家讲讲怎么玩&#xff0c;希望对大家有帮…

Vivado开发FPGA使用流程、教程 verilog(建立工程、编译文件到最终烧录的全流程)

目录 一、概述 二、工程创建 三、添加设计文件并编译 四、线上仿真 五、布局布线 六、生成比特流文件 七、烧录 一、概述 vivado开发FPGA流程分为创建工程、添加设计文件、编译、线上仿真、布局布线&#xff08;添加约束文件&#xff09;、生成比特流文件、烧录等步骤&a…

交叉编译ARM64架构electron详解

基本介绍 本文主要参考Electron官方文档中 构建说明 和 构建步骤(Linux) 在amd64环境内构建arm64的electron包。 如果是arm64环境请查看文章arm64架构编译electron长征路 一、环境说明 操作系统版本:统信1060 操作系统架构:amd64 内存:32G 如下图: electron版本:v25…

企业微信forMAC,如何左右翻动预览图片

1、control commandshifd 进入企业微信的debug调试模式 2、按照如下步骤选择 3、重启企业微信

全球再生环保趋势的热门项目GRS认证

GRS&#xff0c;最初由世优认证&#xff08;CU&#xff09;于2008年制定&#xff0c;并于2011年1月1日将所有权转让给了纺织品交易所TE。 自2017年7月1日GRS4.0版本开始生效。是为在纺织工业的需求所制定&#xff0c;核查回收产品或某些特定产品。更重要的是让零售商和消费者了…

【K8S 存储卷】K8S的存储卷+PV/PVC

目录 一、K8S的存储卷 1、概念&#xff1a; 2、挂载的方式&#xff1a; 2.1、emptyDir&#xff1a; 2.2、hostPath&#xff1a; 2.3、NFS共享存储&#xff1a; 二、PV和PVC&#xff1a; 1、概念 2、请求方式 3、静态请求流程图&#xff1a; 4、PV和PVC的生命周期 5、…

基于ubuntu2204使用kubeadm部署k8s集群

部署k8s集群 基础环境配置安装container安装runc安装CNI插件部署1.24版本k8s集群&#xff08;flannel&#xff09;安装crictl使用kubeadm部署集群节点加入集群部署flannel网络配置dashboard 本集群基于ubuntu2204系统使用kubeadm工具部署1.24版本k8s&#xff0c;容器运行时使用…

Unity | Shader基础知识(第九集:shader常用单词基础知识速成)

目录 一、顶点&#xff08;Vertex&#xff09;和法线(Normal) 二、UV信息 三、 基础数据种类 1 基础数据种类 2 基础数据数组 3 基础数据数组的赋值 4 对数据数组的调用 四、 基础矩阵 1 基础矩阵种类 2 对矩阵数组的调用 2.1对一个数据的调用 2.2对多个数据的调用 2…

js判断当前是否是企业微信环境,微信环境

前言&#xff1a; js判断当前是否是企业微信环境&#xff0c;微信环境 封装方法&#xff1a; function envjudge() {var isMobile window.navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBro…

关于frida定位无误却无法hook到加密方法的见解

一、HOOK不到问题 原先使用 frida -U APP名 -l .\hook.js 这种方法进行hook加密函数&#xff0c;不料始终hook不到&#xff0c;没反应。思考了一下&#xff0c;应该是该app有多个进程&#xff0c;使用上面hook的不是加密进程&#xff0c;古应当用进程pid办法进行hook 二、解决办…

机器之心 AI 技术--人工智能助力个性化视频实战经验分享(文末送书)

【清华社&机器之心】视频生成前沿研究与应用特别活动 在视频生成即将迎来技术和应用大爆发之际&#xff0c;为了帮助企业和广大从业者掌握技术前沿&#xff0c;把握时代机遇&#xff0c;机器之心AI论坛就将国内的视频生成技术力量齐聚一堂&#xff0c;共同分享国内顶尖力量…

华为云AI:轻松实现图像识别调用

文章目录 前言一、环境配置关键步骤 二、图像识别实例媒资图像标签名人识别 总结 前言 基于华为云AI服务和java使用SDK实现图像识别&#xff0c;主要以媒资图像标签和名人识别为例。 一、环境配置 Maven&#xff08;没有直接下载华为的SDK包&#xff0c;而是使用Maven安装依赖…

韩语翻译是怎么收费的

近年来&#xff0c;随着中韩交流的日益密切&#xff0c;韩语翻译在国内的需求呈现出不断增长的态势。无论是韩语笔译还是口译&#xff0c;其应用领域都非常广泛。那么&#xff0c;韩语翻译的价格是否高昂&#xff1f;翻译公司又是如何进行报价的呢&#xff1f; 在翻译领域&…

C2-3.3.2 机器学习/深度学习——数据增强

C2-3.3.2 数据增强 参考链接 1、为什么要使用数据增强&#xff1f; ※总结最经典的一句话&#xff1a;希望模型学习的更稳健 当数据量不足时候&#xff1a; 人工智能三要素之一为数据&#xff0c;但获取大量数据成本高&#xff0c;但数据又是提高模型精度和泛化效果的重要因…

图数据库Gremlin语法(1)| 图基本概念与操作

图数据库Gremlin语法&#xff08;1&#xff09;| 图基本概念与操作 文章目录 图数据库Gremlin语法&#xff08;1&#xff09;| 图基本概念与操作[TOC] 前言一、本章学习重点二、图基本概念三、图基本操作总结 前言 Gremlin语言是图数据库最主流的查询语言&#xff0c;是Apache…

SQL查询连续两个时间段,以Hadoop为例

1、原理&#xff1a; 要实现连续两个时间段的数据查询&#xff0c;网上有很多&#xff0c;我也转载了别人写得比较好的文章。但是最简便的方法是用最原始的方法&#xff0c;将相同数据查询两遍&#xff0c;关联后将两个时间段的数据放在一行。 select a.*,b.列1&#xff0c;b…

Java中的List: 理解与实践

在Java编程语言中&#xff0c;List是一种被广泛使用的集合类型&#xff0c;它提供了一种灵活的方式来存储和操作有序的元素序列。List是Java集合框架&#xff08;Java Collections Framework&#xff09;的一部分&#xff0c;是一个接口&#xff0c;提供了一系列标准的方法来对…

LeetCode_4_困难_寻找两个正序数组的中位数

文章目录 1. 题目2. 思路及代码实现&#xff08;Python&#xff09;2.1 二分查找2.2 划分数组 1. 题目 给定两个大小分别为 m m m 和 n n n 的正序&#xff08;从小到大&#xff09;数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。 算法的时间复杂度应该为…