zoukankan      html  css  js  c++  java
  • ArrayList结构分析(jdk8)

    ArrayList源码分析,基本和Vector一致,去掉了synchronized

        public boolean add(E e) {
            //初始化,扩容
            ensureCapacityInternal(size + 1);  // Increments modCount!!
            //赋值
            elementData[size++] = e;
            return true;
        }
    
        private void ensureCapacityInternal(int minCapacity) {
            //扩容(计算最小扩容容量)
            ensureExplicitCapacity(calculateCapacity(elementData, minCapacity));
        }
        
        //计算扩容后的容量
        private static int calculateCapacity(Object[] elementData, int minCapacity) {
            if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
                return Math.max(DEFAULT_CAPACITY, minCapacity);
            }
            return minCapacity;
        }
        //增加操作数,忽略溢出操作
        private void ensureExplicitCapacity(int minCapacity) {
            modCount++;
    
            // overflow-conscious code
            if (minCapacity - elementData.length > 0)
                grow(minCapacity);
        }
    
        //扩容
        private void grow(int minCapacity) {
            // overflow-conscious code
            int oldCapacity = elementData.length;
            //1.5倍旧容量
            int newCapacity = oldCapacity + (oldCapacity >> 1);
            //不小于最小容量
            if (newCapacity - minCapacity < 0)
                newCapacity = minCapacity;
            //超过最大容量就取最大
            if (newCapacity - MAX_ARRAY_SIZE > 0)
                newCapacity = hugeCapacity(minCapacity);
            //数组复制
            elementData = Arrays.copyOf(elementData, newCapacity);
        }
    
    
  • 相关阅读:
    iOS越狱后必装软件
    构建iOS交叉编译环境
    pycurl库使用详解
    iFiles浏览iphone文件
    Iphone通过ssh进行访问
    YShow性能测试平台搭建
    from my mac
    LR性能分析
    react服务端渲染(七)redux添加
    react服务端渲染(六)路由
  • 原文地址:https://www.cnblogs.com/june777/p/11737514.html
Copyright © 2011-2022 走看看