欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Java集合框架学习(十二) Arrays类详解

程序员文章站 2022-03-11 22:38:38
...

声明:部分内容参考自:https://liuyanzhao.com/2863.html



Arrays类介绍


这个类包含了用于操作数组的各种方法,诸如:排序和搜索。

这个类还包含一个静态方法asList以允许把数组看作list处理。

如果方法引用的数组为null, 方法将会抛出NullPointerException。



类定义


public class Arrays

extends Object



常用方法



1.填充数组:fill


2.数组元素排序:sort


3.比较数组元素是否相等:equals


分析:如果是arr1.equals(arr2),则返回false,因为equals比较的是两个对象的地址,不是里面的数,而Arrays.equals重写了

equals,所以,这里能比较元素是否相等。

这里补充一下,如果还是不用Arrays.equals,那么我们应该如何重写equals来比较两个数组的元素是否相等呢?这里提供一段代码。



4.二分查找法找指定元素的索引值(下标):binarySearch


5.截取数组:copeOf和copeOfRange


6.将数组转换为List处理

注意:

(1)该方法不适用于基本数据类型(byte,short,int,long,float,double,boolean)
(2)该方法将数组与列表链接起来,当更新其中之一时,另一个自动更新
(3)不支持add和remove方法




package com.dylan.collection;

import java.util.Arrays;
import java.util.Iterator;
import java.util.List;

/**
 * 介绍Arrays类的使用
 *
 * @author xusucheng
 * @create 2018-02-04
 **/
public class ArraysDemo {
    public static void main(String[] args) {
        //1. 填充数组fill
        fill();
        //2. 数组元素排序:sort
        sort();
        //3. 比较数组元素是否相等:equals
        equals();
        //4. 二分查找法找指定元素的索引值(下标):binarySearch
        search();
        //5. 截取数组:copeOf和copeOfRange
        copy();
        //6. 将数组转换为List处理
        toList();

    }

    private static void print(int[] a) {
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i] + " ");
        }

        System.out.println();
    }

    private static void fill() {
        int[] arr = new int[5];
        Arrays.fill(arr, 2);

        int[] arr1 = new int[5];
        Arrays.fill(arr1, 1, 3, 8);
        print(arr);
        print(arr1);
    }

    private static void sort(){
        int[] arr = {3,2,1,5,4};
        Arrays.sort(arr);
        int[] arr1 = {3,2,1,5,4};
        Arrays.sort(arr,1,3);
        print(arr);
        print(arr1);
    }

    private static void equals(){
        int[] arr1 = {1,2,3};
        int[] arr2 = {1,2,3};
        System.out.println("arr1=arr2?"+Arrays.equals(arr1,arr2));
    }

    private static void search(){
        int[] arr = {10,20,30,40,50};
        System.out.println(Arrays.binarySearch(arr, 20));
        System.out.println(Arrays.binarySearch(arr, 35));
        System.out.println(Arrays.binarySearch(arr, 0,3,30));
        System.out.println(Arrays.binarySearch(arr, 0,3,40));

    }

    private static void copy(){
        int[] arr = {10,20,30,40,50};
        int[] arr1 = Arrays.copyOf(arr, 3);
        int[] arr2 = Arrays.copyOfRange(arr,1,3);

        print(arr1);
        print(arr2);
    }

    private static void toList(){
        Integer[] arr = {10,20,30,40,50};
        List list = Arrays.asList(arr);
        Iterator it = list.iterator();
        while (it.hasNext()){
            System.out.print(it.next()+" ");
        }
    }
}










相关标签: Arrays