• 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个。   为了提高性能 。

    
                    
  • 相关阅读:
    鸿蒙开发-HarmonyOS UI架构
    YJ的2022CSP游记
    ESP 特权隔离机制—案例研究
    MiniConda在Ubuntu终端的安装
    DTO 模式(数据传输对象)
    【Spring MVC 源码】Spring MVC 如何解析请求
    Llama 3-V: 比GPT4-V小100倍的SOTA
    ASP.net数据从Controller传递到视图
    Zookeeper集群 + Kafka集群
    开源项目丨Taier1.2版本发布,新增工作流、租户绑定简化等多项功能
  • 原文地址:https://blog.csdn.net/MrDaKai/article/details/127700660