java.util.TreeSet.subList() 方法返回此集合中元素范围为 fromElement 的部分的视图到 toElement.如果 fromElement 和 toElement 相等,则返回的集合为空,除非 fromInclusive 和 toInclusive 都为 true。返回的集合由该集合支持,因此返回集合中的更改会反映在该集合中,反之亦然。返回的集合支持该集合支持的所有可选集合操作。
语法
public NavigableSet<E> subSet(E fromElement,
boolean fromInclusive,
E toElement,
boolean toInclusive)
这里,E 是容器维护的元素类型。
参数
fromElement | 指定返回集合的低端点。 |
fromInclusive | 如果低端点包含在返回的视图中,则指定 true。 |
toElement | 指定返回集合的高端点。 |
toInclusive | 指定 true如果高端点包含在返回的视图中。 |
返回值
返回该集合的部分视图其元素范围从 fromElement(包含)到 toElement(不包括)。
Exception
- 抛出 ClassCastException,如果 fromElement 和 toElement 无法比较另一个使用此集合的比较器(或者,如果该集合没有比较器,则使用自然排序)。
- 抛出 NullPointerException,如果 fromElement 或 toElement 为 null 并且此集合使用自然排序,或其比较器不允许 null 元素。
- 如果 fromElement 大于 toElement,则抛出 IllegalArgumentException;或者如果此集合本身有一个受限制的范围,并且 fromElement 或 toElement 位于该范围的边界之外。
示例:
在下面的示例中,java.util.TreeSet.subList() 方法返回给定树集部分的视图。
import java.util.*;
public class MyClass {
public static void main(String[] args) {
//创建树集
TreeSet<Integer> MySet = new TreeSet<Integer>();
TreeSet<Integer> MySubSet = new TreeSet<Integer>();
//填充集合
MySet.add(10);
MySet.add(20);
MySet.add(-30);
MySet.add(40);
MySet.add(50);
MySet.add(-60);
MySet.add(70);
//打印集合
System.out.println("MySet contains: "+ MySet);
//创建集合的部分视图
MySubSet = (TreeSet<Integer>)MySet.subSet(10, false, 50, false);
//打印子集
System.out.println("MySubSet contains: "+ MySubSet);
}
}
上述代码的输出将是:
MySet contains: [-60, -30, 10, 20, 40, 50, 70]
MySubSet contains: [20, 40]