编写高质量代码:改善Java的151个建议七(数组和集合)60-82

该书籍PDF下载地址:http://download.csdn.net/download/muyeju/10001473

60.对基本类型的操作,数组比集合的性能好

  在实际测试中发现:对基本类型进行进行求和计算时数组的效率是集合的10倍。

  用集合进行基本类型的加减,会出现装箱拆箱操作,导致性能消耗

61.若有必要,使用变长数组 

public static <T> T[] expandCapacity(T[] datas ,int newLength){
		newLength = newLength<0?0:newLength ;
		return Arrays.copyOf(datas, newLength) ;
	}

62.警惕数组的浅拷贝

  数组的clone()和Arrays.copyof()都是浅拷贝,即基本类型拷贝的是值,对象拷贝的是引用

63.在明确的场景下,为集合指定初始长度

  ArrayList底层使用的是数组存储,而且数组是定长的,添加数据时,数组的长度是判断是否达到某个临界点,是的话长度就增加临界点的1.5倍,没有数组的长度就还是以前的值。好处是避免了多次调用copyOf()方法的性能开销。默认长度是10

  为什么是增加1.5倍,不是2.5,3.5倍呢?这是因为经过多次测试验证,扩容1.5倍,即满足了性能要求,也减少了内存消耗。

  如果不设置初始值,系统按照1.5倍的规则扩容,每一次扩容就是一次数组的拷贝,如果数据量很大,这样的拷贝会非常消耗资源,而且效率非常低下。但是如果对ArrayList设置了一个适当的初始长度,则可以提高性能。

64.多种最值算法,适时选择

  1.循环判断(当元素小于1W的话,和方法和没什么区别,但是大于1W,还是循环判断性能高些)

public static void main(String[] args) {
        int[] i = {1,5,3,9,4,10,43,21} ;
        int max = i[0] ;
        for(int j = 0 ;j<i.length ;j++){
            max = max>i[j]?max:i[j] ;
        }
        System.out.println("---------"+max);
    
    }    
结果:---------43

  2.先排序,在取值(如果对顺序有要求的话,就的先拷贝一份出来,然后在排序,再取最值)

public static void main(String[] args) {
        int[] i = {1,5,3,9,4,10,43,21} ;
        Arrays.sort(i);
        System.out.println("-------"+i[i.length-1]);
    }

  3.数组中去重在排序

    通过Set的子类TreeSet去重,还能自动排序

public static void main(String[] args) {
        Integer[] i = {1,5,3,9,4,10,43,21,21,4,88} ;
        List<Integer> list = Arrays.asList(i) ;
        TreeSet<Integer> t = new TreeSet<>(list) ;
        int result = t.last() ;
        int result2 = t.lower(result) ; //获得小于最大元素的元素
        System.out.println("----最大---"+result);
        System.out.println("------第二大-----"+result2);
        结果:----最大---88
             ------第二大-----43
    }
    

65.避开基本类型数组转换列表问题

  数组转换成集合通过asList()方法,该方法接受的是一个变成参数(泛型参数),而基本类型是不能泛型化的,要想作为它的泛型参数,就必须使用它的包装类。

  原来类型(基本类型)数组不能作为asList的输入参数,否则会引起程序逻辑混乱

66.asList产生的list对象不可更改

  通过asList产生的集合是一个定长集合,不能再对齐添加、移除,否则会报错。只能进行下面5个方法

  

67.不同的列表,采用不同的排序方法

  随机存取(ArrayList):采用下标方式遍历

  例:

public static void main(String[] args) {
        List<Integer> list = new ArrayList<Integer>(10) ;
        list.add(100) ;
        list.add(123) ;
        list.add(110) ;
        list.add(73) ;
        list.add(0) ;
        long sum = 0l ;
        for(int i=0;i<100000000;i++){
            for(int k=0,size=list.size();k<size;k++){
                sum += list.get(k) ;
            }
        }
    }

  有序存取(LinkList):采用foreach方式遍历

68.频繁插入和删除使用LinkList

  LinkList的插入效率比ArrayList快50倍以上

  大批量的删除动作,LinkList比ArrayList快40倍以上

  ArrayList的修改比LinkList高

69.判断集合是否相等,只需关注元素是否相等即可

70.子列表只是原列表的一个视图

71-82

posted @ 2017-10-11 16:48  孟夏草木长  阅读(243)  评论(0编辑  收藏  举报