java基础-ArrayList

Java ArrayList 是 Java 集合框架(Java Collections Framework)中的一个核心类,属于 java.util 包。它实现了 List 接口,是一个动态数组,可以根据需要自动调整大小(扩容或缩容),提供了比传统数组更灵活的操作方式。

ArrayList 的核心特点

  1. 动态扩容
    • 传统数组(如 int[])长度固定,而 ArrayList 可以动态增长或缩小。
    • 当元素数量超过当前容量时,ArrayList 会自动扩容(通常扩容为原来的 1.5 倍)。
  2. 基于索引的随机访问
    • 支持通过索引(get(index))快速访问元素,时间复杂度为 O(1)
  3. 允许重复元素
    • 可以存储重复的元素(与 Set 不同)。
  4. 有序性
    • 元素按插入顺序存储,可以通过索引访问或遍历。
  5. 非线程安全
    • ArrayList 不是线程安全的,多线程环境下需要手动同步或使用 CopyOnWriteArrayList 等线程安全类。

ArrayList 的基本用法

1. 创建 ArrayList
java 复制代码
import java.util.ArrayList;

// 创建一个空的 ArrayList(默认初始容量为 10)
ArrayList<String> list = new ArrayList<>();

// 指定初始容量(减少扩容次数,提高性能)
ArrayList<Integer> numbers = new ArrayList<>(20);
2. 常用操作
java 复制代码
// 添加元素
list.add("Apple");      // 添加到末尾
list.add(0, "Banana");  // 在索引 0 处插入

// 访问元素
String fruit = list.get(0); // 获取索引 0 的元素

// 修改元素
list.set(0, "Orange"); // 将索引 0 的元素改为 "Orange"

// 删除元素
list.remove(0);        // 删除索引 0 的元素
list.remove("Apple");   // 删除第一个匹配的 "Apple"

// 获取大小
int size = list.size(); // 返回元素数量

// 检查是否包含元素
boolean containsApple = list.contains("Apple");

// 清空列表
list.clear();
3. 遍历 ArrayList
java 复制代码
// 方式 1:增强 for 循环
for (String item : list) {
    System.out.println(item);
}

// 方式 2:迭代器
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {
    System.out.println(iterator.next());
}

// 方式 3:Java 8+ forEach + Lambda
list.forEach(item -> System.out.println(item));

ArrayList vs 数组

特性 ArrayList 数组(如 int[]
长度 动态可变 固定长度
内存开销 稍高(存储额外信息) 较低
功能 提供丰富的 API(如 add()remove() 仅支持基本操作(索引访问)
性能 插入/删除较慢(需移动元素) 随机访问快(O(1))
适用场景 需要频繁增删元素 已知固定大小且无需修改

ArrayList 的底层实现

  • 内部使用数组ArrayList 内部维护了一个 Object[] elementData 数组来存储元素。
  • 扩容机制:当元素数量超过当前数组长度时,会创建一个更大的新数组(通常是原大小的 1.5 倍),并将旧数组内容复制到新数组。

何时使用 ArrayList?

  • 需要频繁增删元素(尤其是末尾)。
  • 需要随机访问元素(通过索引)。
  • 不确定最终数据大小,希望动态调整。

何时避免使用 ArrayList?

  • 多线程环境(需改用 VectorCopyOnWriteArrayList)。
  • 需要频繁在头部或中间 插入/删除元素(考虑 LinkedList)。

示例代码

java 复制代码
import java.util.ArrayList;

public class Main {
    public static void main(String[] args) {
        ArrayList<String> fruits = new ArrayList<>();
        
        // 添加元素
        fruits.add("Apple");
        fruits.add("Banana");
        fruits.add("Cherry");
        
        // 遍历
        for (String fruit : fruits) {
            System.out.println(fruit);
        }
        
        // 删除元素
        fruits.remove("Banana");
        
        // 检查大小
        System.out.println("Size: " + fruits.size());
    }
}

输出:

java 复制代码
Apple
Banana
Cherry
Size: 2
相关推荐
Data_agent4 分钟前
京东商品价格历史信息API使用指南
java·大数据·前端·数据库·python
云技纵横5 分钟前
Stream API 从入门到实践:常用操作、易错点与性能建议
开发语言·windows·python
Knight_AL8 分钟前
Java 17 新特性深度解析:记录类、密封类、模式匹配与增强的 switch 表达式对比 Java 8
java·开发语言
最贪吃的虎12 分钟前
Spring Boot 自动装配(Auto-Configuration)深度实现原理全解析
java·运维·spring boot·后端·mysql
Ahuuua14 分钟前
Spring Bean作用域深度解析
java·后端·spring
大学生资源网14 分钟前
基于Vue的网上购物管理系统的设计与实现(java+vue+源码+文档)
java·前端·vue.js·spring boot·后端·源码
吴佳浩 Alben14 分钟前
Go 1.25.5 通关讲解
开发语言·后端·golang
XXYBMOOO16 分钟前
理解 C++ 中的字节序转换函数 `swapEndian`
开发语言·arm开发·c++
小高Baby@16 分钟前
深入理解golang的GMP模型
开发语言·后端·golang
qq_124987075317 分钟前
基于微信小程序的私房菜定制上门服务系统(源码+论文+部署+安装)
java·spring boot·微信小程序·小程序·毕业设计·毕设