• 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


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

  • 相关阅读:
    hibernate执行createSQLQuery时字段重名的问题
    注意JDBC驱动的版本和JDK的版本是否匹配 JDBC连接Mariadb
    MariaDBConn用于链接MariaDB的管理类
    PLSQL Developer对oracle中的数据进行备份恢复
    JQuery判断浏览器类型
    IE与非IE window.onload调用
    如何升级centos到最新版本
    bootstrap 后台模板
    FontAwesome 4.7.0 中完整的675个图标样式CSS参考
    Linux Crontab及使用salt进行管理
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/4629567.html
Copyright © 2020-2023  润新知