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
相关推荐
谭欣辰5 分钟前
C++ 排列组合完整指南
开发语言·c++·算法
foundbug9991 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab
XDH_CS1 小时前
MySQL 8.0 安装与 MySQL Workbench 使用全流程(超详细教程)
开发语言·数据库·mysql
小短腿的代码世界1 小时前
Qt实时盈亏计算深度解析:从持仓数据到动态盈亏展示
开发语言·qt
小康小小涵2 小时前
基于ESP32S3实现无人机RID模块底层源码编译
linux·开发语言·python
lzjava20242 小时前
Python的函数
开发语言·python
掌心向暖RPA自动化2 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
Awesome Baron2 小时前
skill、tool calling、MCP区别
开发语言·人工智能·python
日取其半万世不竭3 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器