一个集合 - 也叫容器 - 是将多个元素组装成一个单元的简单对象。集合被用来存储、检索、操纵、传送多个数据。尤其是,它用自然组表示数据集合,像一副扑克牌、一个邮件夹、一个电话薄。
集合框架是表示集合和操纵集合的统一结构。所有的集合框架包含:
接口 :代表集合的抽象数据类型。接口允许集合有统一的操作,而不用考虑细节。在面向对象语言中,通常用接口形成层次结构。
实现 :接口的具体实现。本质上,也是可重用的数据结构。
算法 :实现了集合接口的对象的、例如,搜索和排序等执行有效计算的方法。算法是多态的:同养的方法能在很多集合接口的实现中使用。本质上,算法是可重用功能。
除了 java 集合框架,还有 C++ Standard Template Library (STL) 和 Smalltalk 的集合层级。以前,集合框架相当复杂,以至于被认为是难以学习的。我们相信, java 集合框架打破了这个传说,你可以通过本文自学。
Java 集合框架有以下优点:
减少编程工作 :通过提供数据结构和算法,集合框架让你专注于程序的重要部分,而不是专注于建设低级结构( plumbing )。通过促进无关 API 之间影响, java 集合框架使你免于编写适配对象或者转码去联接 API 。
增加程序的速度和质量 :集合框架提供高性能、高质质量的数据结构和算法的实现。每个接口有各种实现供选择,程序可以被简单的调优通过选择集合实现。因为你从写自己的数据结构的苦力中解放,你有很多时间致力于改善程序质量和性能。
允许无关 API 之间的交互 :集合接口通过本地 API 来回传递集合。如果我的网络管理 API 提供一个节点名集合,同时如果你的 GUI 工具期望一个列头集合,我们的 API 将无缝交互,甚至它们是独立开发的。
减少学习使用新 API 的工作 :很多 API 自然地提供输入集合和提供集合输出。过去,每个 API 有一个子 API ,用来操作它的集合,这些子 APi 没有什么一致性,需要从头学,很容易犯错。集合框架的出现,解决了这个问题。
减少设计新 API 的工作 :这个是 以前优势的另一面。设计值和实现者不必每次都为自己的集合设计方法,而是使用标准集合接口。
软件重用 :符合标准集合接口的新数据结构被自然重用。新的算法也同样。