• Java Arrays工具类


    =============Arrays工具类=================
    Arrays:用于操作数组工具类,里面定义了常见操作数组的静态方法。
    常见的有:
    二分查找。排序。将数组变成字符串。

    int[] arr = { 4, 1, 5, 8, 2, 9 };
    System.out.println(Arrays.toString(arr));// 输出 原始数组 [4, 1, 5, 8, 2, 9]
    
    // 对arr进行排序,默认是从小到大。
    Arrays.sort(arr);
    System.out.println(Arrays.toString(arr));// 输出 排序[1, 2, 4, 5, 8, 9]
    
    int index = Arrays.binarySearch(arr, 7);//二分查找(折半查找)
    System.out.println("index=" + index);//如果没有找到,返回 插入点index=-5,负号说明没有找到
    // -5说明 要找的7本应该在   5-1=4的下标, 即现在8的位置
    
    Arrays.fill(arr, 88);//用88来填充整个数组
    System.out.println(Arrays.toString(arr));//[88, 88, 88, 88, 88, 88]

    =================asList:将数组变成集合=====================
        其实就是数组的操作方法较少,可以将数组转成集合后,通过集合的方法来操作数组的元素。
        这样比较方便,但是注意:数组变成集合后,不可以使用增删等改变数组长度的方法。
        如果改变了数组的长度。使用增删等方法会发生UnsupportedOperationException异常。
     
    如果数组中存储的是基本数据类型的元素,那么会将该数组作为集合的元素存在。

    int[] arr = { 3, 1, 5 };
    List<int[]> list = Arrays.asList(arr);
    System.out.println(list);// 输出 : [[I@7919298d]

    如果数组中存储的是引用数据类型的元素,那么变成集合时,这些元素会作为集合的元素存在。

    Integer[] arr = { 3, 1, 5 };
    List<Integer> list = Arrays.asList(arr);
    System.out.println(list);// 输出 : [3, 1, 5]
    list.add(44);// throw "java.lang.UnsupportedOperationException"

    ============集合转换成数组=============
    有时候 需要让集合围成数组,因为有时需要限定对集合中的元素操作,不需要对该元素进行增删。
    这里我们 可以 使用的是Collection接口中的toArray方法。
    在使用toArray方法时,可以传入一个指定类型的数组。
    那么toArray会返回该类型的数组并存储了集合中的元素。
    给toArray方法传递的数组长度该怎么定义呢?
    如果传入的数组长度小于集合的长度,那么该toArray方法内部会建立一个新的该类型的数组,并长度和集合一致,来存储集合的元素。
    如果传入的数组长度大于集合的长度,那么就使用传入的数组存储集合的元素,没有存储数据的位置为null。
    所以传入数组时,该数组长度最好定义成集合的的长度。这就是刚刚好的数组。

    class  ToArrayDemo
    {
        public static void main(String[] args)  
        {
     
            ArrayList<String> al = new ArrayList<String>();
            al.add("abc1");
            al.add("abc2");
            al.add("abc3");
     
            String[] arr = al.toArray(new String[al.size()]);
            System.out.println(Arrays.toString(arr));
        }
    }

     附上关于aslist demo一枚   http://pan.baidu.com/share/link?shareid=66075&uk=3909095065

  • 相关阅读:
    BZOJ 4815: [Cqoi2017]小Q的表格
    BZOJ 3676: [Apio2014]回文串
    BZOJ 4503: 两个串
    BZOJ 2618: [Cqoi2006]凸多边形
    BZOJ 1137: [POI2009]Wsp 岛屿
    BZOJ 4824: [Cqoi2017]老C的键盘
    BZOJ 3167: [Heoi2013]Sao
    BZOJ 4033: [HAOI2015]树上染色
    1003. 我要通过!(20)
    1002. 写出这个数 (20)
  • 原文地址:https://www.cnblogs.com/sishuiliuyun/p/2700101.html
Copyright © 2020-2023  润新知