Java集合核心接口有哪些
时间:2026-02-06 08:51:18 299浏览 收藏
本篇文章向大家介绍《在Java中Collection接口包含哪些内容_Java集合核心接口解析》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。
Collection接口定义的核心方法包括add、remove、contains、size、isEmpty、iterator、toArray、clear,JDK 8+新增removeIf、stream、parallelStream;它不提供get或put因遵循职责分离原则,由List、Map、Set、Queue等子接口/体系承担差异化功能。

Java 中的 Collection 接口本身不包含具体实现,它是一组操作单列集合的顶层契约,定义了增删查、批量操作、迭代和比较等通用行为。真正“包含”的是方法签名和语义约定,而非字段或默认逻辑(JDK 8+ 后增加了少量 default 方法)。
Collection 接口定义的核心方法有哪些
这些方法构成所有单列集合(如 ArrayList、HashSet、LinkedList)必须支持的基础能力:
add(E e):添加元素,返回boolean表示是否成功(例如Set会拒绝重复)remove(Object o):按值删除一个匹配元素(注意不是按索引),依赖equals()contains(Object o):判断是否包含某元素,同样基于equals()size()和isEmpty():获取长度与判空iterator():返回Iterator,是 for-each 循环的底层支撑toArray()及其泛型重载toArray(T[] a):转数组,后者可避免类型擦除问题clear():清空全部元素- JDK 8+ 新增:
removeIf(Predicate super E> filter)、stream()、parallelStream()
为什么 Collection 不提供 get(int index) 或 put(K,V) 这类方法
因为接口设计遵循「职责分离」原则:Collection 描述的是「一组元素」的共性操作,不承诺顺序、不承诺键值映射、也不承诺是否允许重复。这些差异由子接口承担:
- 需要按索引访问?→ 交给
List(它扩展了Collection并添加get(int)、set(int, E)等) - 需要键值对?→ 走
Map体系,它根本不是Collection的子接口(Map是独立顶层接口) - 需要去重且无序?→
Set扩展Collection,但明确禁止重复 - 需要队列行为(FIFO/LIFO)?→
Queue及其子接口(如Deque)添加offer()、poll()等
强行在 Collection 中塞入 get(int),会让 HashSet 这类无索引结构无法合理实现——它连“第 3 个元素”都没定义。
常见误用:把 Collection 当实现类或混淆其与 Iterable 的关系
开发者常犯两类错误:
- 写
Collection list = new ArrayList();—— 语法合法但语义弱,丢失List特有方法(如get()),应优先用具体子接口类型声明 - 以为
Collection继承自Iterable→ 实际上它确实继承了(自 JDK 5),所以能用于 for-each;但反过来,仅实现Iterable的类(如某些自定义数据源)未必是Collection子类,不能直接调用size()或add() - 忽略
Collection方法的异常契约:例如add()在不可变集合(Collections.unmodifiableList()返回值)中会抛UnsupportedOperationException,而非静默失败
public class CollectionBasics {
public static void main(String[] args) {
// 正确:用 List 声明,保留索引能力
List<String> names = new ArrayList<>();
names.add("Alice");
System.out.println(names.get(0)); // ✅
// 危险:用 Collection 声明,后续无法调用 get()
Collection<String> data = new ArrayList<>();
data.add("Bob");
// System.out.println(data.get(0)); // ❌ 编译错误:Collection 没有 get 方法
}
}
真正容易被忽略的是:Collection 的方法行为高度依赖具体实现类的语义。比如 remove(Object) 在 ArrayList 中平均时间复杂度是 O(n),而在 LinkedList 中也是 O(n)(需遍历找节点),但 HashSet 是 O(1)。不看实现就假设性能,线上容易翻车。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
151 收藏
-
381 收藏
-
433 收藏
-
296 收藏
-
321 收藏
-
498 收藏
-
383 收藏
-
264 收藏
-
413 收藏
-
197 收藏
-
135 收藏
-
442 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习