zoukankan      html  css  js  c++  java
  • Java中间(三十五)-----Java详细设置(一个):请指定初始容量设置

            集合是我们在Java编程中使用很广泛的,它就像大海,海纳百川,像万能容器,盛装万物。并且这个大海,万能容器还能够无限变大(假设条件同意)。

    当这个海、容器的量变得很大的时候,它的初始容量就会显得很重要了,由于挖海、扩容是须要消耗大量的人力物力財力的。相同的道理。Collection的初始容量也显得异常重要。

    所以:对于已知的情景。请为集合指定初始容量。

    public static void main(String[] args) {
            StudentVO student = null;
            long begin1 = System.currentTimeMillis();
            List<StudentVO> list1 = new ArrayList<>();
            for(int i = 0 ; i < 1000000; i++){
                student = new StudentVO(i,"chenssy_"+i,i);
                list1.add(student);
            }
            long end1 = System.currentTimeMillis();
            System.out.println("list1 time:" + (end1 - begin1));
            
            long begin2 = System.currentTimeMillis();
            List<StudentVO> list2 = new ArrayList<>(1000000);
            for(int i = 0 ; i < 1000000; i++){
                student = new StudentVO(i,"chenssy_"+i,i);
                list2.add(student);
            }
            long end2 = System.currentTimeMillis();
            System.out.println("list2 time:" + (end2 - begin2));
        }

            上面代码两个list都是插入1000000条数据,仅仅只是list1没有没有申请初始化容量。而list2初始化容量1000000。那执行结果例如以下:

    list1 time:1638
    list2 time:921

            从上面的执行结果我们能够看出list2的速度是list1的两倍左右。

    在前面LZ就提过,ArrayList的扩容机制是比較消耗资源的。

    我们先看ArrayList的add方法:

    public boolean add(E e) {  
            ensureCapacity(size + 1);   
            elementData[size++] = e;  
            return true;  
        }  
        
        public void ensureCapacity(int minCapacity) {  
            modCount++;         //改动计数器
            int oldCapacity = elementData.length;    
            //当前须要的长度超过了数组长度。进行扩容处理
            if (minCapacity > oldCapacity) {  
                Object oldData[] = elementData;  
                //新的容量 = 旧容量 * 1.5 + 1
                int newCapacity = (oldCapacity * 3)/2 + 1;  
                    if (newCapacity < minCapacity)  
                        newCapacity = minCapacity;  
              //数组拷贝,生成新的数组 
              elementData = Arrays.copyOf(elementData, newCapacity);  
            }  
        }

            ArrayList每次新增一个元素。就会检測ArrayList的当前容量是否已经到达临界点,假设到达临界点则会扩容1.5倍。

    然而ArrayList的扩容以及数组的拷贝生成新的数组是相当耗资源的。

    所以若我们事先已知集合的使用场景,知道集合的大概范围,我们最好是指定初始化容量,这样对资源的利用会更加好,尤其是大数据量的前提下。效率的提升和资源的利用会显得更加具有优势。

    >>>>>>java集合细节一:请为集合指定初始容量


    -----原文出自:http://cmsblogs.com/?p=1233,请尊重作者辛勤劳动成果,转载说明出处.

    -----个人网站:http://cmsblogs.com


    版权声明:本文博客原创文章。博客,未经同意,不得转载。

  • 相关阅读:
    20165328《信息安全系统设计基础》实验二固件程序设计实验报告
    20165328《信息安全系统设计基础》第六周学习总结
    2018-2019-1 20165305 20165319 20165328 实验一 开发环境的熟悉
    2018-2019-1 20165328《信息安全系统设计基础》第四周学习总结
    2018-2019-1 20165328 《信息安全系统设计基础》第三周学习总结及实验报告
    20165328《信息安全系统设计基础》第一周总结
    20165358课程总结
    20165328 实验五《网络安全编程》实验报告
    20165218 2018-2019-1 《信息安全系统》第八章学习总结
    2018-2019-1 20165218 实验三 实时系统
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/4629567.html
Copyright © 2011-2022 走看看