• Java(七)——集合框架---ArrayList集合、LinkedList集合


    1 ArrayList集合

    1.1 ArrayList集合的特点

    ArrayList类实现接口List,ArrayList具备了List接口的特性 (有序,重复,索引)

    • ArrayList集合底层的实现原理是数组,大小可变 (数组大小不可变,这里是数组复制)(存储对象的时候长度无需考虑).

    • 数组的特点 : 查询速度快,增删慢.

    • 数组的默认长度是10个,每次的扩容是原来长度的1.5倍.

    • ArrayList是线程不安全的集合,运行速度.

    1.2 ArrayList源码解析

    1.2.1 ArrayList类成员变量

     private static final int DEFAULT_CAPACITY = 10; //默认容量
     private static final Object[] EMPTY_ELEMENTDATA = {};//空数组
    1. transient Object[] elementData; //ArrayList集合中的核心数组
    2. private int size; //记录数组中存储个数
    3. //这里不等于数组长度,数组长度默认为10,当存入一个元素时size才+1
    private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8; //数组扩容的最大值

     数组扩容是有上限的(约21亿个) 超过报OutOfMemoryError

    1.2.2 ArrayList集合类的构造方法

    1. //无参数构造方法
    2. public ArrayList() {
    3. this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
    4. }
    5. //成员变量中
    6. private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {}; //数组没有长度
    7. //但是数组长度默认是10
    8. //在 new ArrayList<>(); 的时候数组赋为空,当给数组村存元素的时候才会变为默认的10个。

    //在  new ArrayList<>();  的时候数组赋为空,当给数组村存元素的时候才会变为默认的10个。   为了提高性能 。

    
                    
  • 相关阅读:
    模型剪枝初级方法
    hping3进行SYN Flood攻击
    微信小程序案例2-3:婚礼邀请函
    在Windows下设置将EXE开机自启动
    今日睡眠质量记录82分
    Qt|QLabel显示刷新图像数据
    华为机试 - 考古学家
    [Spring实战] 整合Spring/SpringMVC/Mybatis(SSM)实现登录功能(带前端)
    springboot基础(31):Mongodb的基本操作
    Linux环境升级npm和node的版本
  • 原文地址:https://blog.csdn.net/MrDaKai/article/details/127700660