ArrayList基于数组实现,支持动态扩容,适用于存储和管理不确定数量的数据。通过add()、set()、remove()等方法可灵活操作元素;支持增强for循环、Iterator、Lambda表达式等多种遍历方式;建议初始化时指定容量以提升性能,避免频繁中间插入删除;多线程环境下需使用同步包装类;结合Collections工具类可高效完成排序、转换等操作。

在Java开发中,ArrayList 是最常用的集合类之一,适用于存储动态数量的数据。它基于数组实现,支持自动扩容,使用起来灵活高效。下面详细介绍如何使用 ArrayList 存储动态数据,并分享一些实用的操作技巧。
添加和管理动态数据
ArrayList 允许你在运行时随时添加、修改或删除元素,非常适合处理不确定数量的数据。
- add(E e):将元素添加到列表末尾
- add(int index, E element):在指定位置插入元素
- set(int index, E element):替换指定位置的元素
- remove(int index) 或 remove(Object o):删除元素
示例:
Listnames.add("张三");
names.add("李四");
names.set(0, "王五"); // 修改第一个元素
names.remove(1); // 删除第二个元素
遍历ArrayList的多种方式
遍历是操作集合的常见需求,ArrayList 支持多种遍历方法,选择合适的方式能提升代码可读性和性能。
立即学习“Java免费学习笔记(深入)”;
- 增强for循环:简洁直观,适合大多数场景
- Iterator:在遍历时安全删除元素的推荐方式
- forEach + Lambda:Java 8+ 的函数式写法,更现代
- 普通for循环:需要索引时使用
示例:
// 增强forfor (String name : names) {
System.out.println(name);
}
// Lambda
names.forEach(System.out::println);
提高性能的小技巧
合理使用 ArrayList 能避免不必要的性能损耗。
- 创建时预设初始容量,减少扩容次数:
new ArrayList(initialCapacity) - 频繁插入/删除中间元素时考虑是否更适合用 LinkedList
- 使用 contains() 前注意时间复杂度为 O(n)
- 多线程环境下应使用 Collections.synchronizedList() 或 CopyOnWriteArrayList
常用工具方法推荐
JDK 提供了便捷的工具类简化操作。
- Collections.sort(list):对列表排序
- Arrays.asList(...):快速创建固定大小的列表(不可变)
- list.isEmpty():判断是否为空,优于 size() == 0
- list.toArray():转换为数组
基本上就这些。掌握这些 ArrayList 的基本用法和优化技巧,能让你更高效地处理动态数据。关键是根据实际场景选择合适的操作方式,避免盲目调用方法。










