java.util
类 TreeSet<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractSet<E>
java.util.TreeSet<E>
所有已实现的接口:
Serializable, Cloneable, Iterable<E>, Collection<E>, Set<E>, SortedSet<E>
public class TreeSet<E>
extends AbstractSet<E>
implements SortedSet<E>, Cloneable, Serializable
此类实现 Set 接口,该接口由 TreeMap 实例支持。此类保证排序后的 set 按照升序排列元素,根据使用的构造方法不同,可能会按照元素的自然顺序 进行排序(参见 Comparable),或按照在创建 set 时所提供的比较器进行排序。
此实现为基本操作(add、remove 和 contains)提供了可保证的 log(n) 时间开销。
注意,如果要正确实现 Set 接口,则 set 所维护的顺序(是否提供了显式比较器)必须为与等号一致(请参阅与等号一致 精确定义的 Comparable 或 Comparator)。这是因为 Set 接口根据 equals 操作进行定义,但 TreeSet 实例将使用其 compareTo(或 compare)方法执行所有的键比较,因此,从 set 的角度出发,该方法认为相等的两个键就是相等的。即使 set 的顺序与等号不一致,其行为也是 定义良好的;它只是违背了 Set 接口的常规协定。
注意,此实现不是同步的。如果多个线程同时访问一个 set,而其中至少一个线程修改了该 set,那么它必须 保持外部同步。通常通过对某个自然封装该 set 的对象进行同步来实现此操作。如果不存在此类对象,则 set 就应该使用 Collections.synchronizedSet 方法进行“包装”。此操作最好在创建时进行,以防止对 set 的意外非同步访问:
SortedSet s = Collections.synchronizedSortedSet(new TreeSet(...));
此类的 iterator 方法返回的迭代器是快速失败的:如果在迭代器创建后的任意时间修改 set(通过迭代器本身remove 方法之外的任何其他方式),迭代器将抛出 ConcurrentModificationException。因此,在并发修改时,迭代器将快速而彻底地失败,而不会在以后的不确定时间有出现任意、无法确定行为的危险。
注意,无法保证迭代器的快速失败行为,因为通常来说,不可能在非同步并发修改的情况下提供任何硬性保证。快速失败的迭代器将尽量抛出 ConcurrentModificationException。因此,为了获得其准确性而编写依赖此异常的程序的做法是错误的:迭代器的快速失败行为应当仅用于检测 bug。
此类是 Java Collections Framework 的成员。
从以下版本开始:
1.2
另请参见:
Collection
, Set
, HashSet
, Comparable
, Comparator
, Collections.synchronizedSortedSet(SortedSet)
,TreeMap
, 序列化表格
构造方法摘要
TreeSet() 构造一个新的空 set,该 set 按照元素的自然顺序排序。 |
TreeSet(Collection<? extends E> c) 构造一个新 set,包含指定 collection 中的元素,这个新 set 按照元素的自然顺序 排序。 |
TreeSet(Comparator<? super E> c) 构造一个新的空 set,该 set 根据指定的比较器进行排序。 |
TreeSet(SortedSet<E> s) 构造一个新 set,该 set 所包含的元素与指定的已排序 set 包含的元素相同,并按照相同的顺序对元素进行排序。 |
方法摘要
boolean |
add(E o) 将指定的元素添加到 set(如果尚未存在于该 set 中)。 |
boolean |
addAll(Collection<? extends E> c) 将指定 collection 中的所有元素添加到此 set 中。 |
void |
clear() 移除 set 中的所有元素。 |
Object |
clone() 返回 TreeSet 实例的浅表复制(并不克隆元素自身)。 |
Comparator<? super E> |
comparator() 返回用于确定已排序 set 顺序的比较器,或者,如果此树 set 使用其元素的自然顺序,则返回null。 |
boolean |
contains(Object o) 如果 set 包含指定的元素,则返回 true。 |
E |
first() 返回已排序 set 中当前的第一个(最小)元素。 |
SortedSet<E> |
headSet(E toElement) 返回此 set 的部分视图,要求其元素严格小于 toElement。 |
boolean |
isEmpty() 如果 set 不包含元素,则返回 true。 |
Iterator<E> |
iterator() 返回对此 set 中的元素进行迭代的迭代器。 |
E |
last() 返回已排序 set 中当前的最后一个(最大)元素。 |
boolean |
remove(Object o) 将指定的元素从 set 中移除(如果该元素存在于此 set 中)。 |
int |
size() 返回 set 中的元素个数(其容量)。 |
SortedSet<E> |
subSet(E fromElement, E toElement) 返回此 set 的部分视图,其元素从 fromElement(包括)到 toElement(不包括)。 |
SortedSet<E> |
tailSet(E fromElement) 返回 set 的部分视图,其元素大于或等于 fromElement。 |
从类 java.util.AbstractSet 继承的方法
equals, hashCode, removeAll |
从类 java.util.AbstractCollection 继承的方法
containsAll, retainAll, toArray, toArray, toString |
从类 java.lang.Object 继承的方法
finalize, getClass, notify, notifyAll, wait, wait, wait |
从接口 java.util.Set 继承的方法
containsAll, equals, hashCode, removeAll, retainAll, toArray, toArray |
TreeSet
public TreeSet()
构造一个新的空 set,该 set 按照元素的自然顺序排序。插入该 set 的所有元素都必须实现 Comparable 接口。而且,所有此类元素必须是可相互比较的:为 set 中的任何元素 e1 和 e2 执行 e1.compareTo(e2) 时必须不抛出ClassCastException。如果用户尝试将违背此约束的元素添加到 set 中(例如,用户试图将字符串元素添加到其元素为整数的 set 中),则 add(Object) 调用将抛出 ClassCastException。
另请参见:
Comparable
TreeSet
public TreeSet(Comparator<? super E> c)
构造一个新的空 set,该 set 根据指定的比较器进行排序。所有插入到该 set 的元素都必须可由指定的比较器相互比较:为 set 中的任何元素 e1 和 e2 执行 comparator.compare(e1, e2) 时必须不抛出 ClassCastException。如果用户尝试将违背此约束的元素添加到 set 中,则 add(Object) 调用将抛出 ClassCastException。
参数:
c
- 用于对此 set 进行排序的比较器。null 值表示应该使用元素的自然顺序。
TreeSet
public TreeSet(Collection<? extends E> c)
构造一个新 set,包含指定 collection 中的元素,这个新 set 按照元素的自然顺序 排序。插入该 set 的所有键都必须实现 Comparable 接口。而且,所有此类键必须是可相互比较的:针对 set 中的任何元素 k1 和 k2 执行k1.compareTo(k2) 必须不抛出 ClassCastException。
参数:
c
- 将组成新 set 的元素。
抛出:
ClassCastException
- 如果指定 collection 中的键不可比较,或不可相互比较。
NullPointerException
- 如果指定的 collection 为 null。
TreeSet
public TreeSet(SortedSet<E> s)
构造一个新 set,该 set 所包含的元素与指定的已排序 set 包含的元素相同,并按照相同的顺序对元素进行排序。
参数:
s
- 已排序的 set,其元素将组成新的 set。
抛出:
NullPointerException
- 如果指定的已排序 set 为 null。
iterator
public Iterator<E> iterator()
返回对此 set 中的元素进行迭代的迭代器。元素以升序返回。
指定者:
接口 Iterable<E>
中的 iterator
指定者:
接口 Collection<E>
中的 iterator
指定者:
接口 Set<E>
中的 iterator
指定者:
类 AbstractCollection<E>
中的 iterator
返回:
对此 set 中的元素进行迭代的迭代器。
size
public int size()
返回 set 中的元素个数(其容量)。
指定者:
接口 Collection<E>
中的 size
指定者:
接口 Set<E>
中的 size
指定者:
类 AbstractCollection<E>
中的 size
返回:
set 中的元素个数(其容量)。
isEmpty
public boolean isEmpty()
如果 set 不包含元素,则返回 true。
指定者:
接口 Collection<E>
中的 isEmpty
指定者:
接口 Set<E>
中的 isEmpty
覆盖:
类 AbstractCollection<E>
中的 isEmpty
返回:
如果 set 不包含元素,则返回 true。
contains
public boolean contains(Object o)
如果 set 包含指定的元素,则返回 true。
指定者:
接口 Collection<E>
中的 contains
指定者:
接口 Set<E>
中的 contains
覆盖:
类 AbstractCollection<E>
中的 contains
参数:
o
- 要在 set 中检查是否包含的对象。
返回:
如果 set 包含指定的元素,则返回 true。
抛出:
ClassCastException
- 如果指定的对象不能与 set 中的当前元素进行比较。
add
public boolean add(E o)
将指定的元素添加到 set(如果尚未存在于该 set 中)。
指定者:
接口 Collection<E>
中的 add
指定者:
接口 Set<E>
中的 add
覆盖:
类 AbstractCollection<E>
中的 add
参数:
o
- 要添加到 set 中的元素。
返回:
如果 set 尚未包含指定的元素,则返回 true。
抛出:
ClassCastException
- 如果指定的对象不能与 set 中的当前元素进行比较。
remove
public boolean remove(Object o)
将指定的元素从 set 中移除(如果该元素存在于此 set 中)。
指定者:
接口 Collection<E>
中的 remove
指定者:
接口 Set<E>
中的 remove
覆盖:
类 AbstractCollection<E>
中的 remove
参数:
o
- 要从 set 移除的对象(如果存在)。
返回:
如果 set 包含指定的元素,则返回 true。
抛出:
ClassCastException
- 如果指定的对象不能与 set 中的当前元素进行比较。
clear
public void clear()
移除 set 中的所有元素。
指定者:
接口 Collection<E>
中的 clear
指定者:
接口 Set<E>
中的 clear
覆盖:
类 AbstractCollection<E>
中的 clear
addAll
public boolean addAll(Collection<? extends E> c)
将指定 collection 中的所有元素添加到此 set 中。
指定者:
接口 Collection<E>
中的 addAll
指定者:
接口 Set<E>
中的 addAll
覆盖:
类 AbstractCollection<E>
中的 addAll
参数:
c
- 要添加的元素。
返回:
如果此 set 随调用的结果发生改变,则返回 true。
抛出:
ClassCastException
- 如果提供的元素不能与 set 中的当前元素进行比较。
NullPointerException
- 如果指定的 collection 为 null。
另请参见:
AbstractCollection.add(Object)
subSet
public SortedSet<E> subSet(E fromElement, E toElement)
返回此 set 的部分视图,其元素从 fromElement(包括)到 toElement(不包括)。(如果 fromElement 与toElement 相等,则返回的已排序 set 为空。)返回的已排序 set 受此 set 支持,所以在返回的已排序 set 中的更改将在此 set 中得到反映,反之亦然。返回的已排序 set 支持所有可选 Set 操作。
如果用户试图插入指定范围之外的元素,那么由此方法返回的已排序 set 将抛出 IllegalArgumentException。
注意:此方法将始终返回一个半开区间(包括低端点,但不包括其高端点)。如果需要闭合区间(同时包括两个端点),并且元素类型允许计算指定值的后继值,则请求从 lowEndpoint 到 successor(highEndpoint) 的子范围即可。例如,假设 s 是一个已排序的字符串 set。下面的语句将获得一个视图,该视图包含 s 中从 low 到 high(包括)的所有字符串:
SortedSet sub = s.subSet(low, high+"�");
可以使用类似的技术生成开放区间(两个端点均不包括)。下面的语句将获得一个视图,该视图包含 s 中从 low 到high(不包括)的所有字符串:
SortedSet sub = s.subSet(low+"�", high);
指定者:
接口 SortedSet<E>
中的 subSet
参数:
fromElement
- subSet 的低端点(包括)。
toElement
- subSet 的高端点(不包括)。
返回:
此 set 的部分视图,其元素从 fromElement(包括)到 toElement(不包括)。
抛出:
ClassCastException
- 如果 fromElement 和 toElement 不能使用此 set 的比较器(或者,如果 set 没有比较器,则使用自然顺序)进行相互比较。
IllegalArgumentException
- 如果 fromElement 大于 toElement。
NullPointerException
- 如果 fromElement 或 toElement 为 null,并且此 set 使用自然顺序,或者其比较器不允许使用 null 元素。
headSet
public SortedSet<E> headSet(E toElement)
返回此 set 的部分视图,要求其元素严格小于 toElement。返回的已排序 set 受此 set 支持,所以在返回的已排序 set 中的更改将反映在此 set 中,反之亦然。返回的已排序 set 支持所有可选 Set 操作。
如果用户试图插入大于或等于 toElement 的元素,那么由此方法返回的已排序 set 将抛出IllegalArgumentException。
注,此方法将始终返回不包含其(高)端点的视图。如果需要包含此端点的视图,而元素类型允许计算指定值的后继值,则请求由 successor(highEndpoint) 指定范围的 headSet 即可。例如,假设 s 是一个已排序的字符串 set。下面的语句将获得一个视图,该视图包含 s 中小于或等于 high 的所有字符串:
SortedSet head = s.headSet(high+"�");
指定者:
接口 SortedSet<E>
中的 headSet
参数:
toElement
- headSet 的高端点(不包括)。
返回:
此 set 的部分视图,要求其元素严格小于 toElement。
抛出:
ClassCastException
- 如果 toElement 与此 set 的比较器不兼容(或者,如果 set 不具有比较器,而 toElement又未实现 Comparable)。
IllegalArgumentException
- 如果 set 本身是 subSet、headSet 或 tailSet,而 toElement 又不在 subSet、headSet 或 tailSet 的指定范围内。
NullPointerException
- 如果 toElement 为 null,并且此 set 使用自然顺序,或者其比较器不允许使用 null 元素。
tailSet
public SortedSet<E> tailSet(E fromElement)
返回 set 的部分视图,其元素大于或等于 fromElement。返回的已排序 set 受此 set 支持,所以在返回的已排序 set 中的更改将反映在此 set 中,反之亦然。返回的已排序 set 支持所有可选 Set 操作。
如果用户试图插入小于 fromElement 的元素,则由此方法返回的已排序 set 将抛出 IllegalArgumentException。注意:此方法将始终返回包含其(低)端点的视图。如果需要不包含此端点的视图,而元素类型允许计算指定值的后继值,则请求由 successor(lowEndpoint) 指定范围的 tailSet 即可。例如,假设 s 是一个已排序的字符串 set。下面的语句将获得一个视图,该视图包含 s 中严格要求大于 low 的所有字符串:
SortedSet tail = s.tailSet(low+"�");
指定者:
接口 SortedSet<E>
中的 tailSet
参数:
fromElement
- tailSet 的低端点(包括)。
返回:
此 set 的部分视图,其元素大于或等于 fromElement。
抛出:
ClassCastException
- 如果 fromElement 与此 set 的比较器不兼容(或者,如果 set 不具有比较器,而fromElement 又未实现 Comparable)。
IllegalArgumentException
- 如果 set 本身是 subSet、headSet 或 tailSet,而 fromElement 又不在 subSet、headSet 或 tailSet 的指定范围内。
NullPointerException
- 如果 fromElement 为 null,并且此 set 使用自然顺序,或者其比较器不允许使用 null元素。
comparator
public Comparator<? super E> comparator()
返回用于确定已排序 set 顺序的比较器,或者,如果此树 set 使用其元素的自然顺序,则返回 null。
指定者:
接口 SortedSet<E>
中的 comparator
返回:
返回用于确定已排序 set 顺序的比较器,或者,如果此树 set 使用其元素的自然顺序,则返回 null。
first
public E first()
返回已排序 set 中当前的第一个(最小)元素。
指定者:
接口 SortedSet<E>
中的 first
返回:
已排序 set 中当前的第一个(最小)元素。
抛出:
NoSuchElementException
- 已排序 set 为空。
last
public E last()
返回已排序 set 中当前的最后一个(最大)元素。
指定者:
接口 SortedSet<E>
中的 last
返回:
已排序 set 中当前的最后一个(最大)元素。
抛出:
NoSuchElementException
- 已排序 set 为空。
clone
public Object clone()
返回 TreeSet 实例的浅表复制(并不克隆元素自身)。
覆盖:
类 Object
中的 clone
返回:
set 的浅表复制。
另请参见:
Cloneable
相关推荐
Java.util包是Java标准库中的核心包之一,它包含了大量用于通用编程的类和接口,是Java开发中不可或缺的一部分。这个包提供了数据结构、集合框架、事件处理、日期时间、随机数生成、位集以及与I/O流操作相关的辅助...
Java.util包是Java标准库中的核心包之一,它包含了大量用于日常编程的工具类和接口。这个包在Java 2版本中得到了显著增强,引入了许多重要的数据结构和算法,为Java程序员提供了更丰富的功能。 首先,Java.util包中...
11. **`java.util.HashSet`** 和 **`java.util.TreeSet`**:两种不同的Set实现,`HashSet`无序且不允许重复元素;`TreeSet`有序,支持自然排序或定制排序。 12. **`java.util.HashMap`** 和 **`java.util.TreeMap`*...
4. `java.util.HashSet` 和 `java.util.TreeSet`: - `HashSet` 是基于哈希表的无序集合,不允许有重复元素,不保证元素顺序。 - `TreeSet` 基于红黑树,自动保持元素的排序,可按照自然顺序或自定义比较器进行...
16. **`java.util.HashSet`** 和 **`java.util.TreeSet`**:两种不同的集合并实现,`HashSet`基于哈希表,`TreeSet`基于红黑树,保证元素有序。 17. **`java.util.HashMap`** 和 **`java.util.TreeMap`**:两种不同...
`java.util.HashSet`和`java.util.TreeSet`分别是无序和有序的集实现,而`java.util.HashMap`和`java.util.TreeMap`则用于存储键值对。 3. **多线程**:Java 6 API中的`java.lang.Thread`类和`java.util.concurrent...
8. **集合(Set)**:集合不包含重复元素,Java提供了`java.util.Set`接口和多种实现,如`java.util.HashSet`和`java.util.TreeSet`。 9. **列表(List)**:列表允许元素重复,且保持元素顺序,如`java.util....
7. **`java.util.HashSet` 和 `java.util.TreeSet`**:这两个类实现了Set接口,`HashSet`基于哈希表,`TreeSet`基于红黑树,它们的区别在于元素的存储方式和排序特性。 8. **`java.util.Scanner`**:用于从输入流...
- `java.util.ArrayList`, `java.util.LinkedList`, `java.util.HashSet`, `java.util.TreeSet`等:不同的集合类型,满足不同数据结构的需求,如顺序访问、快速插入删除、有序存储等。 - `java.util.Map`: 包含`...
Java的`java.util.TreeSet`和`java.util.TreeMap`基于红黑树实现。 7. 图:图是由节点和边构成的数据结构,用于表示对象之间的关系。Java标准库并未提供直接的图实现,但可以通过自定义类或使用第三方库来实现。 8...
Java的`java.util.TreeMap`和`java.util.TreeSet`使用了红黑树实现。 八、红—黑树 红黑树是一种自平衡的二叉查找树,它确保任何节点到其每个叶子节点的路径都具有相同的黑色节点数量,从而保持树的高度平衡。这种...
二叉树是最简单的形式,每个节点最多有两个子节点,Java的`java.util.TreeSet`和`java.util.TreeMap`实现了红黑树。 6. **图**:由节点和边构成,用于表示实体之间的关系。图的遍历算法有深度优先搜索(DFS)和广度...
Java的`java.util.TreeSet`和`java.util.TreeMap`实现了红黑树,这是一种自平衡的二叉查找树。 6. 哈希表:哈希表,也称为散列表,通过键值对存储数据,提供快速的查找、插入和删除操作。Java的`java.util.HashMap`...
7. **树**:在Java中,树数据结构主要用于搜索和排序,如二叉搜索树(`java.util.TreeMap`或`java.util.TreeSet`)。平衡树如AVL树和红黑树可以保持树的高度平衡,提高查找效率。 8. **图**:用于表示对象之间的...
Java中的`java.util.TreeMap`和`java.util.TreeSet`基于红黑树实现。 7. **图**:图是由顶点和边组成的抽象概念,广泛应用于网络、路由、关系等领域。Java中可以使用`java.util.ArrayList`或`java.util.LinkedList`...
例如`java.util.ArrayList`和`java.util.LinkedList`分别对应数组和链表,`java.util.Stack`代表栈,`java.util.Queue`表示队列,`java.util.HashMap`实现了哈希表,`java.util.TreeMap`和`java.util.TreeSet`则是...
Java的`java.util.TreeSet`和`java.util.TreeMap`实现了红黑树。 8. **图**:图由节点和边组成,用于表示对象之间的复杂关系。图的遍历算法包括深度优先搜索(DFS)和广度优先搜索(BFS)。 9. **哈希表**:哈希表...
Java的`java.util.TreeSet`和`java.util.TreeMap`分别实现了二叉搜索树的集合和映射。 7. **图**:由节点(顶点)和连接它们的边构成,用于表示复杂的关系。Java没有内置的图数据结构,但可以通过`java.util....
7. **二叉树**:二叉树每个节点最多有两个子节点,分为二叉搜索树(BST)、平衡二叉树(AVL、红黑树)等,Java的`java.util.TreeMap`和`java.util.TreeSet`基于红黑树实现。 8. **图**:图由顶点和边构成,Java通常...
Java提供了多种方式来实现和操作树结构,其中最常见的是使用Java集合框架中的`java.util.TreeSet`和`java.util.TreeMap`,以及`java.awt.tree.TreeModel`和`javax.swing.JTree`用于图形用户界面的树视图。...