从ArrayList开始学集合是因为它是Java集合的“默认起点”:语法直白、行为贴近可变长数组、API最常用,能快速掌握增删查改与遍历,避开LinkedList的O(n)索引陷阱和HashSet对hashCode/equals的理解门槛。

先学 Collection 接口和 ArrayList,再按「单列→双列→工具→原理」推进,跳过 Vector/Hashtable 等过时类。
为什么从 ArrayList 开始而不是 LinkedList 或 HashSet?
因为它是 Java 集合的「默认起点」:语法最直白、行为最贴近数组(但可变长)、API 最常用。新手卡在 NullPointerException 或 ConcurrentModificationException 前,先得把「增删查改+遍历」跑通。
-
ArrayList的get(int)和add(E)让你立刻理解「索引访问」和「自动扩容」 - 别一上来就碰
LinkedList——它的get(int)是O(n),但初学者常误以为和ArrayList一样快 -
HashSet要求理解哈希码和equals(),没基础容易陷入「明明加了却contains()返回false」的坑
List → Set → Map 的递进逻辑怎么理清?
不是按字母顺序背接口,而是按「你要解决什么问题」来选:
- 要存一堆东西,还要求「能重复、能按顺序取」→ 用
List(ArrayList/LinkedList) - 要存一堆东西,但「不能重复、不care顺序」→ 用
HashSet;如果「还要按插入顺序遍历」→ 换LinkedHashSet - 要存「键值对」,比如
"id" → 1001,且「查 key 要快」→ 用HashMap;如果「key 要排序」→ 换TreeMap
注意:Map 不是 Collection 的子接口,别试图把它当「集合的升级版」——它是独立体系,key 唯一、value 可重复,这点和 Set 容易混淆。
立即学习“Java免费学习笔记(深入)”;
哪些方法必须亲手敲三遍才能记住?
不是背 API 文档,而是盯住这几个高频且易错的操作:
-
Iterator遍历时,remove()必须紧跟next()后调用,直接写list.remove(obj)在迭代中会抛ConcurrentModificationException -
for-each循环里不能调用remove()或add()——它底层就是用Iterator,同上 -
toArray()返回的是Object[],强转成String[]会报ClassCastException;正确写法是list.toArray(new String[0]) -
contains()和remove()对自定义对象生效的前提:重写了hashCode()和equals()
什么时候该看源码或学线程安全?
等你能写出这样的代码并说清每行含义时再动:
ArrayListlist = new ArrayList<>(); list.add("a"); list.add("b"); Iterator it = list.iterator(); while (it.hasNext()) { String s = it.next(); if ("a".equals(s)) it.remove(); // ✅ 安全删除 }
此时再对比 Vector(已淘汰)、Collections.synchronizedList() 和 CopyOnWriteArrayList 的适用场景。别在连 modCount 是啥都不知道时去啃并发源码——90% 的业务根本用不到线程安全集合。
真正容易被忽略的点:泛型擦除后,ArrayList 和 ArrayList 运行时都是 ArrayList,所以反射获取泛型类型必须通过 ParameterizedType;这个坑,等你写通用 DAO 工具类时才会撞上。










