Java 教程
- Java - 首页
- Java - 概述
- Java - 历史
- Java - 特性
- Java 与 C++
- JVM - Java 虚拟机
- Java - JDK 与 JRE 与 JVM
- Java - Hello World 程序
- Java - 环境搭建
- Java - 基本语法
- Java - 变量类型
- Java - 数据类型
- Java - 类型转换
- Java - Unicode 系统
- Java - 基本运算符
- Java - 注释
- Java - 用户输入
- Java - 日期与时间
Java 控制语句
- Java - 循环控制
- Java - 决策制定
- Java - If-else
- Java - Switch
- Java - For 循环
- Java - For-Each 循环
- Java - While 循环
- Java - do-while 循环
- Java - Break
- Java - Continue
面向对象编程
- Java - OOPs 概念
- Java - 对象与类
- Java - 类属性
- Java - 类方法
- Java - 方法
- Java - 变量作用域
- Java - 构造函数
- Java - 访问修饰符
- Java - 继承
- Java - 聚合
- Java - 多态
- Java - 重写
- Java - 方法重载
- Java - 动态绑定
- Java - 静态绑定
- Java - 实例初始化块
- Java - 抽象
- Java - 封装
- Java - 接口
- Java - 包
- Java - 内部类
- Java - 静态类
- Java - 匿名类
- Java - 单例类
- Java - 包装类
- Java - 枚举
- Java - 枚举构造函数
- Java - 枚举字符串
Java 内置类
Java 文件处理
Java 错误与异常
- Java - 异常
- Java - try-catch 块
- Java - try-with-resources
- Java - 多重捕获块
- Java - 嵌套 try 块
- Java - Finally 块
- Java - throw 异常
- Java - 异常传播
- Java - 内置异常
- Java - 自定义异常
Java 多线程
- Java - 多线程
- Java - 线程生命周期
- Java - 创建线程
- Java - 启动线程
- Java - 线程连接
- Java - 线程命名
- Java - 线程调度器
- Java - 线程池
- Java - 主线程
- Java - 线程优先级
- Java - 守护线程
- Java - 线程组
- Java - 关闭钩子
Java 同步
Java 网络
- Java - 网络
- Java - 套接字编程
- Java - URL 处理
- Java - URL 类
- Java - URLConnection 类
- Java - HttpURLConnection 类
- Java - Socket 类
- Java - 泛型
Java 集合
Java 接口
Java 数据结构
Java 集合算法
高级 Java
- Java - 命令行参数
- Java - Lambda 表达式
- Java - 发送电子邮件
- Java - Applet 基础
- Java - Javadoc 注释
- Java - 自动装箱和拆箱
- Java - 文件不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 文件
- Java - 私有接口方法
- Java - 内部类菱形运算符
- Java - 多分辨率图像 API
- Java - 集合工厂方法
- Java - 模块系统
- Java - Nashorn JavaScript
- Java - Optional 类
- Java - 方法引用
- Java - 函数式接口
- Java - 默认方法
- Java - Base64 编码解码
- Java - Switch 表达式
- Java - Teeing 收集器
- Java - 微基准测试
- Java - 文本块
- Java - 动态 CDS 归档
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指针异常
- Java - 打包工具
- Java - 密封类
- Java - 记录类
- Java - 隐藏类
- Java - 模式匹配
- Java - 紧凑数字格式化
- Java - 垃圾回收
- Java - JIT 编译器
Java 杂项
- Java - 递归
- Java - 正则表达式
- Java - 序列化
- Java - 字符串
- Java - Process API 改进
- Java - Stream API 改进
- Java - 增强的 @Deprecated 注释
- Java - CompletableFuture API 改进
- Java - 流
- Java - Datetime Api
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java API 与框架
Java 类参考
- Java - Scanner
- Java - 数组
- Java - 字符串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用资源
Java - SortedSet 接口
SortedSet 接口扩展了Set,并声明了一个按升序排序的集合的行为。除了 Set 定义的方法之外,SortedSet 接口还声明了以下表格中总结的方法 -
当调用集合中不包含任何项目时,几个方法会抛出 NoSuchElementException。当对象与集合中的元素不兼容时,会抛出 ClassCastException。
如果尝试使用空对象并且集合中不允许使用空对象,则会抛出 NullPointerException。
SortedSet 接口方法
序号 | 方法及描述 |
---|---|
1 | Comparator comparator( ) 返回调用 SortedSet 的比较器。如果此集合使用自然排序,则返回 null。 |
2 | Object first( ) 返回调用 SortedSet 中的第一个元素。 |
3 | SortedSet headSet(Object end) 返回一个 SortedSet,其中包含调用 SortedSet 中小于 end 的元素。返回的 SortedSet 中的元素也由调用 SortedSet 引用。 |
4 | Object last( ) 返回调用 SortedSet 中的最后一个元素。 |
5 | SortedSet subSet(Object start, Object end) 返回一个 SortedSet,其中包括 start 和 end 之间的元素。1. 返回的集合中的元素也由调用对象引用。 |
6 | SortedSet tailSet(Object start) 返回一个 SortedSet,其中包含 SortedSet 中大于或等于 start 的元素。返回的集合中的元素也由调用对象引用。 |
SortedSet 接口上的操作
创建 SortedSet
TreeSet 类实现了 SortedSet 接口。我们可以使用 TreeSet 构造函数来创建一个 SortedSet 实例。以下是创建 SortedSet 实例的语法
语法
// Create the sorted set SortedSet<String> set = new TreeSet<>();
这里我们正在创建一个字符串值的排序集。此映射将存储唯一的字符串值。如果添加重复值,则该值将被丢弃。
向 SortedSet 添加值
SortedSet 提供了一个add()方法,该方法可用于向 SortedSet 实例添加值。每当向集合添加值时,都会针对现有值进行检查。如果集合被修改,则方法将返回 true,否则将返回 false。
语法
public boolean add(E e)
其中 E 表示要添加的元素。如果元素已存在,则不会执行任何操作,并且方法将返回 false。
例子
// Add elements to the set set.add("b"); set.add("c"); set.add("a");
从 SortedSet 获取值
为了从 SortedSet 获取值,我们必须使用 iterator() 方法从 SortedSet 获取迭代器对象。一旦迭代器对象可用,该对象就可以用于检索 SortedSet 中存在的值。
例子
// Iterating over the elements in the set Iterator it = set.iterator(); while (it.hasNext()) { // Get element Object element = it.next(); System.out.println(element.toString()); }
从 SortedSet 中删除值
使用remove(value)方法,我们可以轻松地删除存储在 SortedSet 中的值/对象。
语法
public boolean remove(Object value)
如果值不在集合中,则它将返回 false,否则它将删除该值并返回 true。
set.remove("a");
迭代 SortedSet
SortedSet 条目可以轻松导航。SortedSet 提供了一个方法iterator(),该方法提供了一个迭代器来导航集合的所有条目。
语法
public Iterator<E> iterator()
其中 E 是要迭代的对象的类型。
例子
// Iterating over the elements in the set Iterator it = set.iterator(); while (it.hasNext()) { // Get element Object element = it.next(); System.out.println(element.toString()); }
SortedSet 接口的示例
向 SortedSet 添加元素示例
SortedSet 在各种类(如 TreeSet)中都有其实现。以下是具有 add 操作的 TreeSet 类的示例 -
import java.util.Iterator; import java.util.SortedSet; import java.util.TreeSet; public class SortedSetDemo { public static void main(String[] args) { // Create the sorted set SortedSet<String> set = new TreeSet<>(); // Add elements to the set set.add("b"); set.add("c"); set.add("a"); // Iterating over the elements in the set Iterator it = set.iterator(); while (it.hasNext()) { // Get element Object element = it.next(); System.out.println(element.toString()); } } }
输出
a b c
从 SortedSet 中删除元素示例
SortedSet 在各种类(如 TreeSet)中都有其实现。以下是具有 add 和 remove 操作的 TreeSet 类的示例 -
import java.util.Iterator; import java.util.SortedSet; import java.util.TreeSet; public class SortedSetDemo { public static void main(String[] args) { // Create the sorted set SortedSet<String> set = new TreeSet<>(); // Add elements to the set set.add("b"); set.add("c"); set.add("a"); set.add("d"); set.add("e"); set.add("f"); // remove elements set.remove("c"); set.remove("f"); // Iterating over the elements in the set Iterator it = set.iterator(); while (it.hasNext()) { // Get element Object element = it.next(); System.out.println(element.toString()); } } }
输出
a b d e
清除 SortedSet 示例
SortedSet 在各种类(如 TreeSet)中都有其实现。以下是一个带有添加和清除操作的 TreeSet 类的示例:
import java.util.Iterator; import java.util.SortedSet; import java.util.TreeSet; public class SortedSetDemo { public static void main(String[] args) { // Create the sorted set SortedSet<String> set = new TreeSet<>(); // Add elements to the set set.add("b"); set.add("c"); set.add("a"); set.add("d"); set.add("e"); set.add("f"); System.out.println(set); // remove elements set.clear(); System.out.println(set); } }
输出
[a, b, c, d, e, f] []
SortedSet 接口的优点
- SortedSet 确保映射始终按值的升序排序。每当将键值对添加到 SortedSet 时,都会对其重新排序。
- 由于已排序且唯一,因此 SortedSet 在搜索方面非常高效。
- 我们可以通过在值类型上使用比较器来自定义排序机制。
SortedSet 接口的缺点
- 由于 SortedSet 实例在每次添加或更改条目时都必须进行排序,因此在更改非常频繁的情况下,它会成为性能瓶颈。在这种情况下,不建议使用 SortedSet。
- 由于 SortedSet 仅维护唯一记录,因此我们无法在数据集中可能出现重复条目的情况下使用此集合。