Collection 是 Java 单列集合的顶层接口,定义统一操作契约而非具体实现;它规范增删查遍历等五大能力,要求子类支持无参/复制构造、继承 Iterable,并通过 List/Set/Queue 等子接口落实有序性、重复性等特性。

Collection 是 Java 单列集合的顶层接口,它不提供具体实现,只定义所有单列集合共有的行为规范。它的核心职责不是“存数据”,而是“统一操作契约”——让 ArrayList、HashSet、LinkedList 等不同底层结构的集合,都能用一套标准方法增删查遍历。
Collection 的定位与不可实例化特性
它是一个泛型接口(public interface Collection),位于 java.util 包中。JDK 明确不提供它的直接实现类,你不能写 new Collection。必须通过子接口(如 List、Set、Queue)或其实现类(如 ArrayList、HashSet)来使用。
- 它是所有单列集合的“共同父契约”,类似人类的“生物”身份,不指代具体物种
- 所有实现类都必须支持无参构造和带 Collection 参数的构造(用于复制)
- 它继承了
Iterable,因此天然支持增强 for 循环和 lambda 遍历
Collection 规定的五大核心能力
它把集合操作归纳为五类基础行为,每类对应一组强制方法:
- 添加:add(E e) 添加单个元素;addAll(Collection c) 批量添加
- 删除:remove(Object o) 删除首个匹配项;removeAll(Collection c) 删除交集;clear() 彻底清空
- 查询:contains(Object o) 判定存在性(依赖 equals);isEmpty() 和 size() 判断状态与数量
- 遍历:iterator() 返回迭代器(唯一标准方式);forEach(Consumer) 支持函数式处理
- 转换:toArray() 转为 Object[];toArray(T[] a) 转为指定类型数组(类型安全)
它不管“怎么存”,只管“怎么用”
Collection 不关心元素是否有序、是否可重复、是否索引访问、是否线程安全——这些由子接口明确约束:
立即学习“Java免费学习笔记(深入)”;
- List:有序、可重复、有索引 → ArrayList / LinkedList 满足此契约
- Set:无序(HashSet)、插入有序(LinkedHashSet)、排序有序(TreeSet),但都保证不重复
- Queue:强调入队/出队语义,如 offer/poll/peek,FIFO 或优先级顺序
- 注意:Map 不是 Collection 的子接口,它是双列集合,独立于该体系
为什么设计成这样?
这种分层抽象带来三个实际好处:
- 代码解耦:方法参数声明为 Collection
,就能接收 ArrayList、HashSet、甚至自定义集合 - 算法复用:Collections 工具类中的 sort、shuffle、synchronizedCollection 等,全基于 Collection 接口编写
- 学习平滑:掌握 Collection 方法,就掌握了 90% 的集合日常操作,无需为每个实现类重新学 API










