任何一门编程语言,数组都是最重要和常用的数据结构之一,但不同的语言对数组的构造与处理是不尽相同的。

Java中提供了java.util.Arrays 类能方便地操作数组,并且它提供的所有方法都是静态的。下面介绍一下Arrays类最常用的几个方法。

1.  数组排序

Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。

2.  数组转换为字符串

Arrays提供了一个toString方法,可以直接把一个数组转换为字符串,这样可以方便观察数组里的元素。

//来源:公众号【时光与字节】
//数组排序与转换为字符串
package BaseCode;
import java.util.Arrays;
public class j4_1028_11 {
public static void main(String[] args) {
int[] ff= {11,3,25,71,9};
System.out.print("数组ff未排序: ");
for(int n:ff)
System.out.print(n+" ");
Arrays.sort(ff); // 对数组进行排序
System.out.printf("\n数组ff排序后: ");
for(int n:ff)
System.out.print(n+" ");
//将数组转换为字符串
System.out.printf("\n数组ff转为字符串: "+Arrays.toString(ff));
}
}

运行结果

数组ff未排序:
数组ff排序后:
数组ff转为字符串:[, , , , ]

3.  数组元素的填充与替换

Arrays提供了fill方法对数组(或数组指定位置)填充或替换为指定的值。

4.  判断数组是否相同

Arrays.equals可以比较两个数组中的元素是否一样。

//来源:【时光与字节】
//fill方法和equals方法
package BaseCode;
import java.util.Arrays;
public class j4_1028_12 {
public static void main(String[] args) {
int[] ff= new int[5];
Arrays.fill(ff, 5);
System.out.print("数组全部元素填充为5: ");
for(int n:ff)
System.out.print(n+" ");
//将数组从第1个元素至第3个元素填充为7
//含第1个元素,不含第3个元素
Arrays.fill(ff,1,3,7);
System.out.print("\n数组指定位置填充为7: ");
for(int n:ff)
System.out.print(n+" ");
int[] nn= new int[5];
Arrays.fill(nn, 5);
System.out.printf("\nff与nn相同:"+Arrays.equals(ff, nn));
}
}

运行结果

数组全部元素填充为5:
数组指定位置填充为7:
ff与nn相同:false

5.  复制数组

Arrays类的copyOf()方法和copyRange()方法可以实现对数组的复制。

copyOf(arr, int newlength)

参数newlength为新数组的长度,即从数组arr的第0个位置开始,直到newlength结束,如果newlength大于arr的长度,后面按默认值填充。

copyOfRange(arr, int formIndex, int toIndex)

参数formIndex为从数组arr中取元素的开始位置,toIndex为结束位置,但不包括该位置的元素,如toIndex超出arr的长度,后面按默认值填充。

//来源:公众号【时光与字节】
//数组的复制,copyOf与copyOfRange的使用
package BaseCode;
import java.util.Arrays;
public class j4_1028_10 {
public static void main(String[] args) {
int[] ff= {1,3,5,7,9};
//Arrays.copyOf复制数组至指定长度,从0开始
int[] newff1=Arrays.copyOf(ff, 3);
int[] newff2=Arrays.copyOf(ff, 6);
System.out.print("copyOf的使用:\n数组newff1: ");
for(int n:newff1)
System.out.print(n+" ");
System.out.printf("\n数组newff2: ");
for(int n:newff2)
System.out.print(n+" ");
//Arrays.copyOfRange第二个参数为开始位置
//第三个参数为结束位置
int[] newff3=Arrays.copyOfRange(ff, 1, 4);
int[] newff4=Arrays.copyOfRange(ff, 1, 7);
System.out.printf("\ncopyOfRange的使用:\n数组newff3: ");
for(int n:newff3)
System.out.print(n+" ");
System.out.printf("\n数组newff4: ");
for(int n:newff4)
System.out.print(n+" ");
}
}

运行结果

copyOf的使用:
数组newff1:
数组newff2:
copyOfRange的使用:
数组newff3:
数组newff4:

6.  元素查询

Arrays类的binarySearch 方法可以查询元素出现的位置,返回元素的索引。但是注意,使用binarySearch进行查找之前,必须使用sort进行排序。并且如果数组中有多个相同的元素,查找结果是不确定的。

binarySearch(arr, object key)

如果key在数组中,则返回搜索值的索引;否则返回-1或者负的插入点值。

所谓插入点值就是第一个比key大的元素在数组中的索引,而且这个索引是从1开始的。

binarySearch(arr, int fromIndex, int endIndex, object key);

fromIndex:指定范围的开始处索引(包含

toIndex:指定范围的结束处索引(不包含

其搜索结果可分为以下四种情况:

  1. 该搜索键不在范围内,且大于范围(数组)内元素,返回 –(toIndex + 1);

  2. 该搜索键不在范围内,且小于范围(数组)内元素,返回–(fromIndex + 1);

  3. 该搜索键在范围内,但不是数组元素,由1开始计数,返回负的插入点索引值;

  4. 该搜索键在范围内,且是数组元素,由0开始计数,返回搜索值的索引值;

参看下面的示例代码及注释

//来源:公众号【时光与字节】
//查找数组元素:binarySearch 方法的使用
package BaseCode;
import java.util.Arrays;
public class j4_1028_13 {
public static void main(String[] args) {
int[] fn= {1,3,5,7,9};
Arrays.sort(fn);//查找前先排序
int cx1=Arrays.binarySearch(fn,5);//返回2 ,找到了关键字,索引从0开始
//未找到6,返回的是负的插入点值,
//6在数组中的插入点是元素7的索引,
//元素7的索引从1开始算就是4,所有返回-4
int cx2=Arrays.binarySearch(fn,6);//未找到,返回-4,插入点7的索引是4
int cx3=Arrays.binarySearch(fn,4);//未找到,返回-3,插入点5的索引是3
System.out.println("不指定查找范围示例:");
System.out.println("数组fn的内容:"+Arrays.toString(fn));
System.out.printf("[5]找到:cx1=%d%n", cx1);
System.out.printf("[6][4]未找到:cx2=%d, cx3=%d%n", cx2,cx3); //在数组的指定位置查找元素,参数范围(1,3)包含的数组元素为[3,5]
//该搜索键不在范围内,且大于范围(数组)内元素,返回 –(toIndex + 1)。
int cx4=Arrays.binarySearch(fn,1,3,10);
//该搜索键不在范围内,且小于范围(数组)内元素,返回–(fromIndex + 1);
int cx5=Arrays.binarySearch(fn,1,3,-3);
//该搜索键在范围内,但不是数组元素,由1开始计数,返回负的插入点索引值
int cx6=Arrays.binarySearch(fn,1,3,4);
//该搜索键在范围内,且是数组元素,由0开始计数,返回搜索值的索引值
int cx7=Arrays.binarySearch(fn,1,3,5);
System.out.println("-------------------------");
System.out.println("用参数指定查找范围示例:");
System.out.println("第一种情况:cx4= "+cx4);
System.out.println("第二种情况:cx5= "+cx5);
System.out.println("第三种情况:cx6= "+cx6);
System.out.println("第四种情况:cx7= "+cx7);
}
}

运行结果

不指定查找范围示例:
数组fn的内容:[, , , , ]
[]找到:cx1=
[][]未找到:cx2=-, cx3=-
-------------------------
用参数指定查找范围示例:
第一种情况:cx4= -
第二种情况:cx5= -
第三种情况:cx6= -
第四种情况:cx7=

Java中数组操作 java.util.Arrays 类常用方法的使用的更多相关文章

  1. Java中的操作日期的工具类

    import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; imp ...

  2. 【java】java.util.Arrays类常用方法

    package Arrays类; import java.util.Arrays; public class TestArrays { public static void main(String[] ...

  3. 慕课网-Java入门第一季-6-7 使用 Arrays 类操作 Java 中的数组

    来源:http://www.imooc.com/code/1556 Arrays 类是 Java 中提供的一个工具类,在 java.util 包中.该类中包含了一些方法用来直接操作数组,比如可直接实现 ...

  4. [19/03/12-星期二] 数组_遍历(for-each)&复制&java.util.Arrays类

    一.遍历 for-each即增强for循环,是JDK1.5新增加的功能,专门用于读取数组或集合中所有的元素,即对数组进行遍历. //数组遍历 for-each public class Test_03 ...

  5. Java中创建操作文件和文件夹的工具类

    Java中创建操作文件和文件夹的工具类 FileUtils.java import java.io.BufferedInputStream; import java.io.BufferedOutput ...

  6. JDK1.8源码(四)——java.util.Arrays 类

    java.util.Arrays 类是 JDK 提供的一个工具类,用来处理数组的各种方法,而且每个方法基本上都是静态方法,能直接通过类名Arrays调用. 1.asList public static ...

  7. java.util.Arrays类详解(源码总结)

    概述 Arrays类位于java.util包下,是一个对数组操作的工具类.今天详细的看了看Arrays类的4千多行源码,现将Arrays类中的方法做一个总结(JDK版本:1.6.0_34).Array ...

  8. java.util.Arrays类

    前言:java.util.Arrays类的技术文档请查看Oracle官网 1.Arrays类常见方法: 本文参考资料:百度文库:Oracle官网:第三方中文技术文档

  9. java基础-Arrays类常用方法介绍

    java基础-Arrays类常用方法介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Array类的概念 此类包含用来操作数组(比如排序和搜索)的各种方法.需要注意,如果指定 ...

随机推荐

  1. Hadoop点滴-Hadoop的IO

    Hadoop自带一套原子操作用于数据的I/O操作. 如果系统中需要处理的数据量达到Hadoop的处理极限时,数据被损害的概率还是很高的 检测数据是否被损害的常见措施是,在数据第一次被引进系统时,计算校 ...

  2. Linux 部署vsftp服务及详解

    一.FTP服务概述: FTP服务器(File Transfer Protocol Server)是在互联网上提供文件存储和访问服务的计算机,它们依照FTP协议提供服务. FTP(File Transf ...

  3. Linux 文件或文件夹重命名命令mv

    使用命令mv既可以重命名,又可以移动文件或文件夹.例如: 1.将目录A重命名为B mv A B 2.将/a目录移动到/b下,并重命名为c mv /a /b/c 3.将一个名为abc的文件重命名为123 ...

  4. 在网页中打印一个99乘法表--JavaScript描述

    99乘法表使用for循环,在很多公司的面试中常会要求面试者手写这个算法,算是比较经典的for循环的应用 <!DOCTYPE html><html lang="en" ...

  5. Flask框架踩坑之ajax跨域请求

    业务场景: 前后端分离需要对接数据接口. 接口测试是在postman做的,今天才开始和前端对接,由于这是我第一次做后端接口开发(第一次嘛,问题比较多)所以在此记录分享我的踩坑之旅,以便能更好的理解,应 ...

  6. Dropout原理与实现

    Dropout是深度学习中的一种防止过拟合手段,在面试中也经常会被问到,因此有必要搞懂其原理. 1 Dropout的运作方式 在神经网络的训练过程中,对于一次迭代中的某一层神经网络,先随机选择中的一些 ...

  7. ELK 学习笔记之 Logstash之output配置

    Logstash之output配置: 输出到file 配置conf: input{ file{ path => "/usr/local/logstash-5.6.1/bin/spark ...

  8. Timed out after 30000 ms while waiting to connect

    今天使用mongo-java-drive写连接mongo的客户端,着实被上面那个错坑了一把.回顾一下解决过程: 报错: com.mongodb.MongoTimeoutException: Timed ...

  9. 搭建docker+swoole+php7 的环境

    最近在学习swoole php扩展,苦恼于其运行环境不能在win系统下运行, 但开发代码一直在win系统上,很无奈,,,, 所以就用docker来代替,舒服~ 有很多相关docker的swoole镜像 ...

  10. centos 7安装rac 11gR2时运行root.sh报错找不到ohas服务(ohasd failed to start)

    单独在linux 7中为ohasd设置一个服务.步骤如下1. 创建服务ohas.service的服务文件并赋予权限touch /usr/lib/systemd/system/ohas.servicec ...