核心集合接口(**core collection interfaces**封装不同类型的集合,如下图所示。这些接口允许独立于其表示的细节来操纵集合。核心集合接口是Java Collections Framework的基础。正如你可以从下图看到的,核心集合接口形成一个层次。
    接口 - 图1
    核心集合接口
    Set是一种特殊的CollectionSortedSet是一种特殊的Set,依此类推。 还请注意,层次结构由两棵不同的树组成——Map不是真正的Collection
    请注意,所有核心集合接口都是泛型的。例如,这是Collection接口的声明。

    1. public interface Collection<E>...

    语法<E>告诉你,接口是泛型的。声明Collection实例时,可以并且应该指定集合中包含的对象的类型。指定类型可以使编译器在编译时,验证您放入集合中的对象类型是否正确,从而减少了运行时的错误。有关泛型类型的信息,请参见 泛型(更新)课程。
    当您了解如何使用这些接口时,您将了解有关Java Collections Framework的大部分知识。本章讨论有效使用接口的一般准则,包括何时使用哪个接口。您还将学习每种接口的编程习惯用法,以帮助您充分利用接口。
    为了使核心集合接口的数量易于管理,Java平台没有为每种集合类型的每个变体提供单独的接口。(此类变体可能包括不可变的,固定大小的和仅附加的。)相反,每个接口中的修改操作都指定为可选 -给定的实现可能选择不支持所有操作。如果调用了不受支持的操作,则集合将引发 UnsupportedOperationException。实现负责记录支持哪些可选操作。所有Java平台的泛型实现都支持所有可选操作。
    下表描述了核心集合接口:

    • Collection——集合层次结构的根。集合表示一组称为其元素的对象。Collection接口是所有集合实现的最小公分母,用于在需要最大通用性时传递集合并对其进行操作。某些类型的集合允许重复的元素,而其他类型则不允许。一些是有序的,而其他则是无序的。Java平台不提供此接口的任何直接实现,但是提供更特定的子接口的实现,例如Set和List。另请参见“集合接口”部分。
    • Set——不能包含重复元素的集合。该接口对数学集合的抽象进行建模,并用于表示集合,例如包含扑克手的纸牌,构成学生时间表的课程或机器上运行的过程。另请参见 “Set接口”部分。
    • List——有序集合(有时称为序列(sequence)。List(列表)可以包含重复的元素。List的用户通常可以精确控制List中每个元素的插入位置,并可以通过其整数索引(位置)访问元素。 如果您使用过Vector,那么您将熟悉List的一般风格。 另请参见“List接口”部分。
    • Queue——用于在处理之前保存多个元素的集合。除了基本的集合操作外,Queue(队列)还提供其他插入,提取和检查操作。

    Queue通常但不一定以FIFO(先进先出)的方式对元素进行排序。优先队列除外,它们根据提供的比较器或元素的自然顺序对元素进行排序。无论使用哪种顺序,队列的开头都是将通过调用removepoll删除的元素。在FIFO队列中,所有新元素都插入到队列的尾部。其他种类的队列可能使用不同的放置规则。每个Queue实现必须指定其排序属性。另请参见“Queue接口”部分。

    • Deque——用于在处理之前容纳多个元素的集合。除了基本的收集操作外Deque(双端队列)还提供其他插入,提取和检查操作。

    双端队列可同时用作FIFO(先进先出)和LIFO(先进先出)。在双端队列中,所有新元素都可以在两端插入,检索和删除。 另请参见Deque接口部分。

    • Map—将键映射到值的对象。一个Map不能包含重复键; 每个键最多可以映射到一个值。如果您曾经使用过Hashtable,则已经熟悉Map的基础知识。另请参见 “Map接口”部分。

    最后两个核心集合接口仅仅是SetMap的排序版本:

    • SortedSet——一个Set,以升序维护其元素。提供了一些附加操作以利用排序的优势。排序的集合用于自然排序的集合,例如单词列表和成员资格列表。另请参见SortedSet接口部分。
    • SortedMap——一个按键升序维护其映射的Map。 这是类似SortedSetMap实现。排序的Map用于键/值对的自然排序集合,例如字典和电话簿。另请参见SortedMap接口部分。

    要了解排序后的接口如何维护其元素的顺序,请参见“对象排序”部分。