Java知识系统回顾整理01基础06数组07数组工具类Arrays

一、Arrays简介

Arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。

   

二、Arrays提供的数组复制方法

使用System.arraycopy进行数组复制类似的, Arrays提供了一个copyOfRange方法进行数组复制。

不同的是System.arraycopy,需要事先准备好目标数组,并分配长度。 copyOfRange 只需要源数组就就可以了,通过返回值,就能够得到目标数组了。

除此之外,需要注意的是 copyOfRange 的第3个参数,表示源数组的结束位置,是取不到的

   

import java.util.Arrays;

   

public class HelloWorld {

    public static void main(String[] args) {

        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };

   

        // copyOfRange(int[] original, int from, int to)

        // 第一个参数表示源数组

        // 第二个参数表示开始位置(取得到)

        // 第三个参数表示结束位置(取不到)

        int[] b = Arrays.copyOfRange(a, 0, 3);

   

        for (int i = 0; i < b.length; i++) {

            System.out.print(b[i] + " ");

        }

    }

}

   

三、Arrays提供的转换为字符串方法

如果要打印一个数组的内容,就需要通过for循环来挨个遍历,逐一打印

但是Arrays提供了一个toString()方法,直接把一个数组,转换为字符串,这样方便观察数组的内容

import java.util.Arrays;

    

public class HelloWorld {

    public static void main(String[] args) {

        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };

        String content = Arrays.toString(a);

        System.out.println(content);  

    }

}

   

四、Arrays提供的排序方法

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

import java.util.Arrays;

    

public class HelloWorld {

    public static void main(String[] args) {

        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };

        System.out.println("排序之前 :");

        System.out.println(Arrays.toString(a));

        Arrays.sort(a);

        System.out.println("排序之后:");

        System.out.println(Arrays.toString(a));

    

    }

}

   

五、Arrays提供的查询元素位置的方法

查询元素出现的位置

需要注意的是,使用binarySearch进行查找之前,必须使用sort进行排序(注:亲测,使用binarySearch进行查找之前,不必用sort排序)

如果数组中有多个相同的元素,查找结果是不确定的

import java.util.Arrays;

   

public class HelloWorld {

    public static void main(String[] args) {

        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };

   

        Arrays.sort(a);

   

        System.out.println(Arrays.toString(a));

        //使用binarySearch之前,必须先使用sort进行排序

        System.out.println("数字 62出现的位置:"+Arrays.binarySearch(a, 62));

    }

}

   

六、Arrays提供的判断数组元素是否相同的方法

比较两个数组的内容是否一样

第二个数组的最后一个元素是8,和第一个数组不一样,所以比较结果是false

import java.util.Arrays;

   

public class HelloWorld {

    public static void main(String[] args) {

        int a[] = new int[] { 18, 62, 68, 82, 65, 9 };

        int b[] = new int[] { 18, 62, 68, 82, 65, 8 };

   

        System.out.println(Arrays.equals(a, b));

    }

}

   

七、Arrays提供的填充数组元素的方法

使用同一个值,填充整个数组

import java.util.Arrays;

    

public class HelloWorld {

    public static void main(String[] args) {

        int a[] = new int[10]; 

        Arrays.fill(a, 5);  

        System.out.println(Arrays.toString(a)); 

    }

}

   

八、练习--二维数组排序

题目:

首先定义一个5X8的二维数组,然后使用随机数填充满。

借助Arrays的方法对二维数组进行排序。

参考思路:

先把二维数组使用System.arraycopy进行数组复制到一个一维数组

然后使用sort进行排序

最后再复制回到二维数组。

   

关于随机数

0-100的 随机整数的获取办法有多种,下面是参考办法之一:

(int) (Math.random() * 100)

Math.random() 会得到一个0-1之间的随机浮点数,然后乘以100,并强转为整型即可。

   

官方示例代码:

import java.util.Arrays;

   

public class HelloWorld {

    public static void main(String[] args) {

        int a[][] = new int[5][8];

        for (int i = 0; i < a.length; i++) {

            for (int j = 0; j < a[i].length; j++) {

                a[i][j] = (int) (Math.random() * 100);

            }

        }

   

        System.out.println("打印二维数组");

        for (int[] i : a) {

            System.out.println(Arrays.toString(i));

        }

   

        // 把二维数组复制到一维数组

        int b[] = new int[a.length * a[0].length];

        for (int i = 0; i < a.length; i++) {

            System.arraycopy(a[i], 0, b, i * a[i].length, a[i].length);

        }

        // 对一维数组进行排序

        Arrays.sort(b);

        // 把一维数组复制到二维数组

        for (int i = 0; i < a.length; i++) {

            System.arraycopy(b, a[i].length * i, a[i], 0, a[i].length);

        }

        System.out.println("打印排序后的二维数组");

        for (int[] i : a) {

            System.out.println(Arrays.toString(i));

        }

    }

}

   

   

   

原文地址:https://www.cnblogs.com/xlfcjx/p/10775595.html