Java ArrayList的底层实现方法

Java中的ArrayList是一种动态数组数据结构,底层通过数组实现,其大小可以随时增加或缩小。ArrayList可以存储任何类型的数据,而不仅仅是对象。下面将介绍Java ArrayList的底层实现方法。

一、数据结构

ArrayList底层的数据结构是数组,其构造方法为:

public ArrayList() {
    this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}

其中elementData是一个Object类型的数组,表示ArrayList中存储元素的数组,而DEFAULTCAPACITY_EMPTY_ELEMENTDATA是一个空数组,初始大小为0.

在添加元素时,ArrayList首先检查elementData数组是否为空,如果是,则重新创建一个大小为10的数组。

private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
private static final int DEFAULT_CAPACITY = 10;
public boolean add(E e) {
    ensureCapacityInternal(size + 1);
    elementData[size++] = e;
    return true;
}
private void ensureCapacityInternal(int minCapacity) {
        ensureExplicitCapacity(calculateCapacity(elementData, 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;
    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);
}

可以发现,当添加元素时,ArrayList会调用ensureCapacityInternal方法来确保elementData数组的容量足够,如果不够则调用grow方法进行扩容。grow方法会创建一个新的数组,并将旧数组中的元素复制到新数组中。

二、例子

添加元素

ArrayList<String> list = new ArrayList<>();
list.add("Hello");
list.add("World");

在这个例子中,我们创建了一个ArrayList对象,并向其中添加了两个元素。当添加第一个元素时,elementData数组为空,ArrayList会创建一个大小为10的数组。当添加第二个元素时,elementData数组大小为1,由于ArrayList底层实现为动态数组,因此会自动扩容为20,将旧数组中的元素复制到新数组中,并添加新的元素。

删除元素

list.remove(0);

在这个例子中,我们通过索引删除了ArrayList中的第一个元素。ArrayList删除元素会涉及到数组的移位操作,因此效率不如添加元素高。

三、总结

Java ArrayList底层实现方法是通过动态数组来实现的,其数据结构为数组,每次添加或删除元素时,ArrayList会检查elementData数组容量是否足够,如果不够则扩容并复制旧数组中的元素到新数组中。由于ArrayList底层实现为数组,删除元素需要涉及到数组的移位操作,因此效率不高。

阅读剩余 35%

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java ArrayList的底层实现方法 - Python技术站

(0)
上一篇 2023年5月26日
下一篇 2023年5月26日

相关文章

  • JS笛卡尔积算法与多重数组笛卡尔积实现方法示例

    JS笛卡尔积算法用来计算多个数组的所有组合结果,它可以轻松地计算多个数组之间的笛卡尔积。下面是JS笛卡尔积算法的实现过程: 实现过程 首先我们需要创建一个空的结果数组,用于存储所有的组合结果。 然后我们需要用for循环嵌套来遍历所有的数组元素。 在遍历的过程中,我们需要用concat方法将数组元素进行组合,并将组合结果添加到结果数组中。 最后,我们返回结果数…

    Java 2023年5月19日
    00
  • Java DelayQueue实现任务延时示例讲解

    让我详细讲解一下“Java DelayQueue实现任务延时示例讲解”的完整攻略。 什么是DelayQueue DelayQueue 是一个基于优先级队列 PriorityQueue 实现的无界阻塞队列,用于放置在给定延迟时间后才能被消费的元素(任务)。DelayQueue 中的元素必须实现 java.util.concurrent.Delayed 接口,该…

    Java 2023年5月20日
    00
  • Java实现批量向mysql写入数据的方法

    当需要向mysql中插入大批量数据时,通过Java程序向数据库逐一插入会比较慢,而批量插入可以提高插入效率。下面就讲解一下如何Java实现批量向mysql写入数据的方法。 1. 准备工作 在开始之前,需要先检查好已经安装好了Mysql的Java驱动,可以在官网下载或在maven中引入即可。 另外,在写程序之前,需要先创建一个mysql表,以下示例代码将插入数…

    Java 2023年5月20日
    00
  • MyBatis-Plus 修改和添加自动填充时间方式

    让我给您详细讲解”MyBatis-Plus 修改和添加自动填充时间方式”的完整攻略。 什么是自动填充时间? MyBatis-Plus(简称 MP)是 MyBatis 的增强工具,可以轻松地实现 MyBatis 中的常见操作,如分页。自动填充时间功能是 MP 的一项重要功能之一,它可以在往表中插入记录和修改记录时,自动填充时间字段,无需手动设置。 MP 自动填…

    Java 2023年5月20日
    00
  • java SpringSecurity使用详解

    Java Spring Security使用详解 什么是Spring Security? Spring Security是Spring框架中一个强大的安全管理框架。它提供了一个全面而灵活的安全管理机制,可以让你轻松地管理应用程序中的身份验证、授权和其他安全相关的一切。 Spring Security 的核心概念 Authentication(认证) Auth…

    Java 2023年5月19日
    00
  • 编码为GB2312网站让AJAX接收的数据显示支持中文

    为了让 AJAX 接收的数据支持中文,我们需要考虑两个方面:编码和显示。 编码 首先,我们需要将网站的编码设置为 GB2312。这可以通过在 HTML head 标签中添加以下代码实现: <meta http-equiv="Content-Type" content="text/html; charset=gb2312&q…

    Java 2023年6月15日
    00
  • Eclipse中maven异常Updating Maven Project的统一解决方案

    以下是“Eclipse中maven异常Updating Maven Project的统一解决方案”的完整攻略。 问题背景 在使用Eclipse和Maven进行开发时,我们会发现当我们修改了代码并保存后,Eclipse并不会自动更新Maven项目依赖。当我们手动更新依赖时,有时会遇到”Maven updating”的问题,此时需要符合maven规范的项目结构,…

    Java 2023年5月20日
    00
  • Java之理解多态详解

    Java之理解多态详解 什么是多态 多态是指同样的消息可以被不同的对象接收和处理。 在实现时,一个父类的变量可以引用一个子类的对象,这个引用既可以调用父类中定义的方法,也可以调用子类中重写父类方法的方法。 多态的实现需要满足三个条件: 继承:多态必须存在于父类和子类之间. 重写:在子类中对父类的方法进行重新定义. 向上转型:使用父类类型的引用指向子类对象. …

    Java 2023年5月26日
    00
合作推广
合作推广
分享本页
返回顶部