zoukankan      html  css  js  c++  java
  • Arrays类

    Arrays类



    Arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。

    import java.util.Arrays;
    

    关键字 简介 示例
    copyOf(int[] original, int newLength) 把数组original中的元素复制到一个新的数组中, 新数组的长度是newLength
    copyOfRange(int[] original, int from, int to) 把数组[ from,to )范围的元素复制到新数组中 示例
    toString(int[] a) 把数组的元素转换为字符串 示例
    deepToString(Object[] a) 把多维数组的元素转换为字符串
    sort 对数组进行排序,包括对象数组 示例
    parallelSort(int[] a) 数组排序, 适用于数组非常大的情况
    binarySearch 在数组a中查找元素key, 返回key在数组中的索引值, 如果数组中不存在该元素返回负数.(要求数组已经按照从大到小排序) 示例
    equals 判断是否相同 示例
    fill 填充 示例
    List、asList 可以把数组转换为List列表



    copyOfRange

    与使用System.arraycopy进行数组复制类似的, Arrays提供了一个copyOfRange方法进行数组复制。
    不同的是System.arraycopy,需要事先准备好目标数组,并分配长度。 copyOfRange 只需要源数组就就可以了,通过返回值,就能够得到目标数组了。
    除此之外,需要注意的是 copyOfRange 的第3个参数,表示源数组的结束位置,是取不到的

    int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
     
    // copyOfRange(int[] original, int from, int to)
    // 第一个参数表示源数组
    // 第二个参数表示开始位置(取得到)
    // 第三个参数表示结束位置(取不到)
    int[] b = Arrays.copyOfRange(a, 0, 3);         
    



    toString

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

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

    int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
            String content = Arrays.toString(a);
            System.out.println(content);
    



    sort

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

    int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
    Arrays.sort(a);
    System.out.println("排序之后:");
    

    sort方法也可以对对象进行排序

    //对数组排序,可以指定一个Comparator比较器
    //Comparator后面<T>是一个泛型,指定比较元素的数据类型
    Arrays.sort(data,new Comparator<Product>(){ 
        //在服名内部类中重写Comparator接口的抽象方法,指定比较规则 
        @override 
        public int compare(Product o1,Product o2){ 
            //根据价格的升序 
            return ol.price-o2.price; //如果是升序,第一个对象大于第二个对象返间正数,第一个对 
            return o2.price-ol.price;//价格降序
        }
    });
    



    binarySearch

    查询元素出现的位置
    需要注意的是,使用binarySearch进行查找之前,必须使用sort进行排序
    如果数组中有多个相同的元素,查找结果是不确定的

    int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
    Arrays.sort(a);
    //使用binarySearch之前,必须先使用sort进行排序
    System.out.println("数字 62出现的位置:"+Arrays.binarySearch(a, 62));
    



    equals

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



    fill

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

    Arrays.fill(a, 5);
    





  • 相关阅读:
    SSL 数据加密原理简述
    MQTT 协议 部分细节
    ARM汇编--汇编中符号和变量
    Kconfig 配置文件编码规则
    ARM汇编指令-STMFD/LDMFD
    python类属性和对象属性、类的普通方法和静态方法
    ARM汇编---程序获取符号的物理地址
    Spring源码分析:非懒加载的单例Bean初始化前后的一些操作
    Spring源码分析:非懒加载的单例Bean初始化过程(下)
    Spring源码分析:非懒加载的单例Bean初始化过程(上)
  • 原文地址:https://www.cnblogs.com/huochemeiyouhuo/p/12379874.html
Copyright © 2011-2022 走看看