【Java基础】实用工具类Arrays,让使用数组更轻松。

简介: 学习了解实用工具类Arrays,让使用数组更轻松。

Java实用工具类


java.util.Arrays类(操作数组)


1.boolean equals(int[],int[])

2.String toString(int[])

3.void fill(int[] a,int fromIndex,int toIndex,int val)

4.void sort(int[] a)

5.int binarySearch(int[] a,int key)

6.int[] copyOf(int[],int newLength)


java.util.Arrays类(操作数组)


使用前的准备:导包

import java.util.Arrays;


1.boolean equals(int[],int[])


boolean equals(int[],int[])方法:

可以用于判断两个数组是否相等,返回值是布尔类型(true或false)

案例:

import java.util.Arrays;
/**
 * @author .29.
 * @create 2022-09-11 11:34
 */
public class ArraysTool {
    public static void main(String[] args) {
        int[] arr1 = new int[]{1,2,3,4,5,6};
        int[] arr2 = new int[]{1,2,3,4,5,6};
        int[] arr3 = new int[]{1,4,3,2,5};
        int[] arr4 = arr1;
        int[] arr5 = new int[]{};
        int[] arr6 = new int[]{};
        //与相等数组比较
        boolean eql1 = Arrays.equals(arr1,arr2);
        //与不相等数组比较
        boolean eql2 = Arrays.equals(arr1,arr3);
        //数组与本身比较
        boolean eql3= Arrays.equals(arr1,arr4);
        //与空数组比较
        boolean eql4= Arrays.equals(arr1,arr5);
        //两个空数组比较
        boolean eql5= Arrays.equals(arr5,arr6);
        System.out.println("与相等数组比较:"+eql1);
        System.out.println("与不等数组比较:"+eql2);
        System.out.println("数组与本身比较:"+eql3);
        System.out.println("与空数组的比较:"+eql4);
        System.out.println("两个空数组比较:"+eql5);
    }
}

控制台输出:

微信图片_20221028215607.png

2.String toString(int[])


String toString(int[])方法,可以用来输出数组,将数组转化成字符串,返回值是String类型。

案例:

import java.util.Arrays;
/**
 * @author .29.
 * @create 2022-09-11 11:34
 */
public class ArraysTool {
    public static void main(String[] args) {
        int[] arr = new int[]{1,2,3,4,5,6};
        int[] arr1 = new int[]{};
        int[] arr2 = null;
        System.out.println(Arrays.toString(arr));
        System.out.println(Arrays.toString(arr1));
        System.out.println(Arrays.toString(arr2));
    }
}

控制台输出:

微信图片_20221028215617.png

3.void fill(int[] a,int fromIndex,int toIndex,int val)


void fill(int[] a,int fromIndex,int toIndex,int val) 方法,可以用来将指定的值填入到数组当中,没有返回值(返回值为空)。

注意:该方法用于填充覆盖原有的元素,不能用于增添元素,否则出现数组下标越界异常(java.lang.ArrayIndexOutOfBoundsException)


案例:

import java.util.Arrays;
/**
 * @author .29.
 * @create 2022-09-11 11:34
 */
public class ArraysTool {
    public static void main(String[] args) {
        int[] arr = new int[]{1,2,3,4,5,6};
        int a = 29;
        int b = 24;
        //(int[],int)不指定下标,完全填充
        Arrays.fill(arr,a);
        System.out.println(Arrays.toString(arr));
        //(int[],int fromIndex,int toIndex,int)指定下标
        // 从fromIndex到toIndex前的元素被填充
        Arrays.fill(arr,1,2,b);
        Arrays.fill(arr,4,6,24);
        //输出
        System.out.println(Arrays.toString(arr));
        //以下情况为不填充
        Arrays.fill(arr,1,1,b);
        Arrays.fill(arr,2,2,b);
        Arrays.fill(arr,3,3,b);
    }
}

控制台输出:

微信图片_20221028215625.png


4.void sort(int[] a)


void sort(int[] a)方法,可用来对数组进行排序,返回值为空(没有返回值)。

案例:

LeetCode原题链接:最小K个数

题目:面试题 17.14. 最小K个数

题目描述:设计一个算法,找出数组中最小的k个数。以任意顺序返回这k个数均可。
示例:
输入: arr = [1,3,5,7,2,4,6,8], k = 4
输出: [1,2,3,4]

实现代码:

class Solution {
    public int[] smallestK(int[] arr, int k) {
        //开辟空间,用于存放最小k个数
        int[] nums = new int[k];
        //调用Arrays工具类的sort()方法,排序数组。
        Arrays.sort(arr);
        //将排序好数组的前k个数复制到开辟的空间中
        for(int i = 0;i < k; ++i){
            nums[i] = arr[i];
        }
        //返回
        return nums;
    }
}

提交结果:

微信图片_20221028215640.png


5.int binarySearch(int[] a,int key)


int binarySearch(int[] a,int key)方法,用于对排序好的数组进行二分法查找指定的值,返回查找到指定值的下标。

案例:

import java.util.Arrays;
/**
 * @author .29.
 * @create 2022-09-11 11:34
 */
public class ArraysTool {
    public static void main(String[] args) {
        int[] arr = new int[]{1,2,3,4,5,6,7,8};
        int a = Arrays.binarySearch(arr,1);
        int b = Arrays.binarySearch(arr,2);
        int c = Arrays.binarySearch(arr,3);
        int d = Arrays.binarySearch(arr,4);
        int e = Arrays.binarySearch(arr,5);
        int f = Arrays.binarySearch(arr,6);
        int g = Arrays.binarySearch(arr,7);
        int h = Arrays.binarySearch(arr,8);
        System.out.println(a+" "+b+" "+c+" "+d+" "+e+" "+f+" "+g+" "+h);
       //未排序
        int[] arr1 = {4,8,6,1,3,2,5,7};
        a = Arrays.binarySearch(arr1,1);
        b = Arrays.binarySearch(arr1,2);
        c = Arrays.binarySearch(arr1,3);
        d = Arrays.binarySearch(arr1,4);
        e = Arrays.binarySearch(arr1,5);
        f = Arrays.binarySearch(arr1,6);
        g = Arrays.binarySearch(arr1,7);
        h = Arrays.binarySearch(arr1,8);
        System.out.println(a+" "+b+" "+c+" "+d+" "+e+" "+f+" "+g+" "+h);
    }
}


控制台输出:

未排序数组使用binarySearch(int[] a,int key)方法效果不理想。

微信图片_20221028215650.png


6.int[] copyOf(int[],int newLength)


copyOf()方法用于复制一个数组,可以指定返回数组的长度。

案例(与sort()方法案例一致):

void sort(int[] a)方法,可用来对数组进行排序,返回值为空(没有返回值)。

案例:

LeetCode原题链接:最小K个数

题目:面试题 17.14. 最小K个数

题目描述:设计一个算法,找出数组中最小的k个数。以任意顺序返回这k个数均可。
示例:
输入: arr = [1,3,5,7,2,4,6,8], k = 4
输出: [1,2,3,4]

实现代码:

class Solution {
    public int[] smallestK(int[] arr, int k) {
        //调用Arrays工具类的sort()方法,排序数组。
        Arrays.sort(arr);
       //将排序好的数组复制一份副本,指定副本长度为k
        int[] nums = Arrays.copyOf(arr,k);
        //返回
        return nums;
    }
}

题解结果:

微信图片_20221028215657.png

补充:如果返回数组的指定长度newLength长度大于被拷贝数组长度,多出来的位置会被0替代。

案例:

import java.util.Arrays;
/**
 * @author .29.
 * @create 2022-09-11 11:34
 */
public class ArraysTool {
    public static void main(String[] args) {
        int[] arr2 = {29,29,29,29,29};
      int[] ints = Arrays.copyOf(arr2, 10);
        System.out.println(Arrays.toString(ints));
    }
}

控制台输出:

微信图片_20221028215706.png

总结:熟练使用工具类,可以减少代码量,有效提升工作效率,但是不要因此而忽略巩固基础。

微信图片_20221028215712.jpg



目录
相关文章
|
14天前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
37 17
|
6天前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
10天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
50 4
|
11天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
26 2
|
15天前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
|
19天前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
|
19天前
|
Java API Maven
如何使用 Java 字节码工具检查类文件的完整性
本文介绍如何利用Java字节码工具来检测类文件的完整性和有效性,确保类文件未被篡改或损坏,适用于开发和维护阶段的代码质量控制。
|
19天前
|
存储 Java 编译器
java wrapper是什么类
【10月更文挑战第16天】
22 3
|
22天前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
21 5
|
22天前
|
Java
在Java多线程编程中,实现Runnable接口通常优于继承Thread类
【10月更文挑战第20天】在Java多线程编程中,实现Runnable接口通常优于继承Thread类。原因包括:1) Java只支持单继承,实现接口不受此限制;2) Runnable接口便于代码复用和线程池管理;3) 分离任务与线程,提高灵活性。因此,实现Runnable接口是更佳选择。
30 2