主页
  • 主页
  • 分类
  • 热文
  • 教程
  • 面试
  • 标签
Java

Java 基础

Java 主页
Java 概述
Java 历史
Java 功能
Java 与 C++
Java 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 面向对象编程

Java OOP概念
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 数组
Java 数学类

Java 文件处理

Java 文件
Java 创建文件
Java 写入文件
Java 读取文件
Java 删除文件
Java 目录操作
Java I/O流

Java 错误和异常

Java 异常
Java Try Catch
Java try-with-resources
Java 多个 Catch
Java 嵌套 try
Java finally
Java 抛出异常
Java 异常传播
Java 内置异常
Java 自定义异常

Java 多线程

Java 多线程
Java 线程生命周期
Java 创建线程
Java 启动线程
Java 加入线程
Java 命名线程
Java 线程调度
Java 线程池
Java 主线程
Java 线程优先级
Java 守护线程
Java 线程组
Java JVM 关闭

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 映射接口
Java SortedMap 接口
Java 集合(Set)接口
Java SortedSet 接口

Java 数据结构

Java 数据结构
Java 枚举接口

Java 集合算法

Java 迭代器
Java 比较器
Java Comparable 接口

Java 高级

Java 命令行参数
Java Lambda 表达式
Java 发送电子邮件
Java 小应用程序
Java Javadoc
Java 自动装箱和拆箱
Java mismatch() 方法
Java REPL
Java 多版本发布 JAR
Java 私有接口方法
Java 金刚石操作符
Java 多分辨率图像 API
Java 集合的工厂方法
Java 模块系统
Java Nashorn 引擎
Java Optional 类
Java 方法引用
Java 功能接口
Java 默认方法
Java Base64 工具类
Java Switch 表达式
Java Collectors.teeing() 方法
Java 基准测试
Java 文本块
Java 动态CDS
Java ZGC
Java NullPointerException
Java jpackage
Java 密封类
Java 记录
Java 隐藏类
Java instanceof
Java 紧凑数字格式化
Java 垃圾回收
Java JIT 编译器

Java 杂项

Java 递归
Java 正则表达式
Java 序列化
Java 字符串类
Java 进程 API
Java Stream API
Java @Deprecated 注释
Java CompletableFuture API
Java Streams
Java 日期时间 API

基础

Java 主页
Java 概述
Java 历史
Java 功能
Java 与 C++
Java JVM(Java虚拟机)
Java JDK、JRE 和 JVM
Java Hello World 程序
Java 环境设置
Java 基本语法
Java 变量类型
Java 数据类型
Java 类型转换
Java Unicode 系统
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 OOP概念
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 数学类

文件处理

Java 文件
Java 创建文件
Java 写入文件
Java 读取文件
Java 删除文件
Java 目录操作
Java I/O流

错误和异常

Java 异常
Java Try Catch
Java try-with-resources
Java 多个 Catch
Java 嵌套 try
Java finally
Java 抛出异常
Java 异常传播
Java 内置异常
Java 自定义异常

多线程

Java 多线程
Java 线程生命周期
Java 创建线程
Java 启动线程
Java 加入线程
Java 命名线程
Java 线程调度
Java 线程池
Java 主线程
Java 线程优先级
Java 守护线程
Java 线程组
Java JVM 关闭

同步

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 SortedMap 接口
Java 集合(Set)接口
Java SortedSet 接口

数据结构

Java 数据结构
Java 枚举接口

集合算法

Java 迭代器
Java 比较器
Java Comparable 接口

高级

Java 命令行参数
Java Lambda 表达式
Java 发送电子邮件
Java 小应用程序
Java Javadoc
Java 自动装箱和拆箱
Java mismatch() 方法
Java REPL
Java 多版本发布 JAR
Java 私有接口方法
Java 金刚石操作符
Java 多分辨率图像 API
Java 集合的工厂方法
Java 模块系统
Java Nashorn 引擎
Java Optional 类
Java 方法引用
Java 功能接口
Java 默认方法
Java Base64 工具类
Java Switch 表达式
Java Collectors.teeing() 方法
Java 基准测试
Java 文本块
Java 动态CDS
Java ZGC
Java NullPointerException
Java jpackage
Java 密封类
Java 记录
Java 隐藏类
Java instanceof
Java 紧凑数字格式化
Java 垃圾回收
Java JIT 编译器

杂项

Java 递归
Java 正则表达式
Java 序列化
Java 字符串类
Java 进程 API
Java Stream API
Java @Deprecated 注释
Java CompletableFuture API
Java Streams
Java 日期时间 API

Java SortedMap 接口


上一章 下一章

SortedMap 接口扩展了 Map 接口。它确保条目按照键的升序排列。

几个方法会在没有元素存在于调用映射时抛出 NoSuchElementException。当一个对象与映射中的元素不兼容时,会抛出 ClassCastException。如果尝试使用空对象而映射不允许空,则会抛出 NullPointerException。

SortedMap 接口方法

SortedMap 接口中声明的方法总结如下:

序号 方法 & 描述
1 Comparator comparator()
返回调用排序映射的比较器。如果使用自然顺序,则返回 null。
2 Object firstKey()
返回调用映射的第一个键。
3 SortedMap headMap(Object end)
返回一个排序映射,其中包含键小于 end 的映射条目。
4 Object lastKey()
返回调用映射的最后一个键。
5 SortedMap subMap(Object start, Object end)
返回一个映射,其中包含键大于或等于 start 且小于 end 的条目。
6 SortedMap tailMap(Object start)
返回一个映射,其中包含键大于或等于 start 的条目。

SortedMap 接口层次结构

下图显示了 Java 中 SortedMap 接口的层次结构:

Hierarchy Diagram of SortedMap Interface

SortedMap 接口上的操作

创建 SortedMap

TreeMap 类实现了 SortedMap 接口。我们可以使用 TreeMap 构造器来创建一个 SortedMap 实例。

语法:

// 创建一个排序映射
SortedMap<String, Double> map = new TreeMap<>();

这里我们创建了一个 String 对 Double 值的排序映射。这个映射将基于字母数字顺序存储键。

向 SortedMap 添加值

SortedMap 提供了 put() 方法,可以用来向排序映射实例添加值。每当值被添加到映射中时,映射会自动根据输入的键进行排序。

语法:

public V put(K key, V value)

这里的键值对表示相互关联的键和值,并存储在映射中。如果此键已经与一个值相关联,则返回那个值,并且新的值与键相关联;否则返回 null 值。

从 SortedMap 获取值

使用 get(key) 方法,我们可以检索与键相关联的值。

语法:

public V get(Object key)

如果键不在映射中,则返回 null;否则返回提供的键所关联的值。

更新 SortedMap 的值

我们可以通过再次调用带有相同键的 put() 方法来更新排序映射中现有的值。作为一个排序映射,在重新输入键之后,条目将再次根据排序顺序进行排序。

从排序映射删除值

使用 remove(key) 方法,我们可以删除与键相关联的值。

语法:

public V remove(Object key)

如果键不在映射中,则返回 null;否则它将从映射中删除键值关联,并相应地对映射进行排序。

遍历 SortedMap

SortedMap 条目可以轻松导航。SortedMap 提供了一个 entrySet() 方法,该方法以集合的形式提供所有条目。

语法:

public Set<Map.Entry<K, V>> entrySet()

其中 Map.Entry 包含要迭代的键值对。

SortedMap 接口示例

示例 1

下面是一个示例,说明如何使用 TreeMap 获取 SortedMap 的值:

import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.SortedMap;
import java.util.TreeMap;

public class MapDemo {

   public static void main(String args[]) {
      // 创建一个排序映射
      SortedMap<String, Double> map = new TreeMap<>();

      // 向映射中添加元素
      map.put("Zara", Double.valueOf(3434.34));
      map.put("Mahnaz", Double.valueOf(123.22));
      map.put("Ayan", Double.valueOf(1378.00));
      map.put("Daisy", Double.valueOf(99.22));
      map.put("Qadir", Double.valueOf(-19.08));

      // 获取条目的集合
      Set<Map.Entry<String, Double>> set = map.entrySet();

      // 获取迭代器
      Iterator<Map.Entry<String, Double>> i = set.iterator();

      // 显示元素
      while (i.hasNext()) {
         Map.Entry<String, Double> me = i.next();
         System.out.print(me.getKey() + ": ");
         System.out.println(me.getValue());
      }
   }
}

输出:

Ayan: 1378.0
Daisy: 99.22
Mahnaz: 123.22
Qadir: -19.08
Zara: 3434.34

示例 2

下面是一个示例,说明如何使用 TreeMap 设置 SortedMap 的值:

import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.SortedMap;
import java.util.TreeMap;

public class MapDemo {

   public static void main(String args[]) {
      // 创建一个排序映射
      SortedMap<String, Double> map = new TreeMap<>();

      // 向映射中添加元素
      map.put("Zara", Double.valueOf(3434.34));
      map.put("Mahnaz", Double.valueOf(123.22));
      map.put("Ayan", Double.valueOf(1378.00));
      map.put("Daisy", Double.valueOf(99.22));
      map.put("Qadir", Double.valueOf(-19.08));

      // 获取条目的集合
      Set<Map.Entry<String, Double>> set = map.entrySet();

      // 获取迭代器
      Iterator<Map.Entry<String, Double>> i = set.iterator();

      // 显示元素
      while (i.hasNext()) {
         Map.Entry<String, Double> me = i.next();
         me.setValue(me.getValue() * 10);
         System.out.print(me.getKey() + ": ");
         System.out.println(me.getValue());
      }
   }
}

输出:

Ayan: 13780.0
Daisy: 992.2
Mahnaz: 1232.2
Qadir: -190.79999999999998
Zara: 34343.4

示例 3

下面是一个示例,说明如何使用 TreeMap 获取 SortedMap 条目的键:

import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.SortedMap;
import java.util.TreeMap;

public class MapDemo {

   public static void main(String args[]) {
      // 创建一个排序映射
      SortedMap<String, Double> map = new TreeMap<>();

      // 向映射中添加元素
      map.put("Zara", Double.valueOf(3434.34));
      map.put("Mahnaz", Double.valueOf(123.22));
      map.put("Ayan", Double.valueOf(1378.00));
      map.put("Daisy", Double.valueOf(99.22));
      map.put("Qadir", Double.valueOf(-19.08));

      // 获取条目的集合
      Set<Map.Entry<String, Double>> set = map.entrySet();

      // 获取迭代器
      Iterator<Map.Entry<String, Double>> i = set.iterator();

      // 显示元素
      while (i.hasNext()) {
         Map.Entry<String, Double> me = i.next();
         System.out.println(me.getKey());
      }
   }
}

输出:

Ayan
Daisy
Mahnaz
Qadir
Zara

SortedMap 接口的优点

SortedMap 确保映射总是按照键的升序排列。每当键值对被添加到排序映射时,都会重新排序。 由于已排序,SortedMap 在搜索方面非常高效。对于大型只读数据集,SortedMap 是理想的实现选择。 我们可以使用键类型的比较器来自定义排序机制。

SortedMap 接口的缺点

由于 SortedMap 每次添加或更改条目时都必须排序,因此在频繁更改的情况下会成为性能瓶颈。在这种情况下,SortedMap 不被推荐。 由于 SortedMap 根据键维护可排序性,所以键应该可以比较,因此我们不能使用未实现 Comparable 接口的自定义键。

上一章 下一章
阅读号二维码

关注阅读号

联系二维码

联系我们

© 2024 Yoagoa. All rights reserved.

粤ICP备18007391号

站点地图