Java 教程
- Java - 首页
- Java - 概述
- Java - 历史
- Java - 特性
- Java 与 C++
- JVM - Java 虚拟机
- Java - JDK vs JRE vs 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 - 多重 catch 块
- 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 - Socket 编程
- 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 - 日期时间 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 - TreeMap 类
TreeMap 类使用树实现 Map 接口。TreeMap 提供了一种有效的方式来按排序顺序存储键值对,并允许快速检索。
请注意,与哈希映射不同,TreeMap 保证其元素将按升序键顺序排序。
以下是 TreeMap 类支持的构造函数列表。
序号 | 构造函数和描述 |
---|---|
1 | TreeMap( ) 此构造函数构建一个空的 TreeMap,它将使用其键的自然顺序进行排序。 |
2 | TreeMap(Comparator comp) 此构造函数构建一个空的基于树的映射,它将使用 Comparator comp 进行排序。 |
3 | TreeMap(Map m) 此构造函数使用来自 m 的条目初始化一个 TreeMap,它将使用键的自然顺序进行排序。 |
4 | TreeMap(SortedMap sm) 此构造函数使用来自 SortedMap sm 的条目初始化一个 TreeMap,它将按与 sm 相同的顺序进行排序。 |
除了从其父类继承的方法外,TreeMap 还定义了以下方法:
序号 | 方法和描述 |
---|---|
1 | void clear() 从此 TreeMap 中删除所有映射。 |
2 | Object clone() 返回此 TreeMap 实例的浅拷贝。 |
3 | Comparator comparator() 返回用于对该映射进行排序的比较器,如果该映射使用其键的自然顺序,则返回 null。 |
4 | boolean containsKey(Object key) 如果此映射包含指定键的映射,则返回 true。 |
5 | boolean containsValue(Object value) 如果此映射将一个或多个键映射到指定值,则返回 true。 |
6 | Set entrySet() 返回此映射中包含的映射的 Set 视图。 |
7 | Object firstKey() 返回当前在此排序映射中的第一个(最低)键。 |
8 | Object get(Object key) 返回此映射将指定键映射到的值。 |
9 | SortedMap headMap(Object toKey) 返回此映射的一部分的视图,其键严格小于 toKey。 |
10 | Set keySet() 返回此映射中包含的键的 Set 视图。 |
11 | Object lastKey() 返回当前在此排序映射中的最后一个(最高)键。 |
12 | Object put(Object key, Object value) 在此映射中将指定值与指定键关联。 |
13 | void putAll(Map map) 将指定映射中的所有映射复制到此映射。 |
14 | Object remove(Object key) 如果存在,则从此 TreeMap 中删除此键的映射。 |
15 | int size() 返回此映射中键值映射的数量。 |
16 | SortedMap subMap(Object fromKey, Object toKey) 返回此映射的一部分的视图,其键范围从 fromKey(包含)到 toKey(不包含)。 |
17 | SortedMap tailMap(Object fromKey) 返回此映射的一部分的视图,其键大于或等于 fromKey。 |
18 | Collection values() 返回此映射中包含的值的集合视图。 |
示例
以下程序说明了此集合支持的几种方法:
import java.util.*; public class TreeMapDemo { public static void main(String args[]) { // Create a hash map TreeMap tm = new TreeMap(); // Put elements to the map tm.put("Zara", new Double(3434.34)); tm.put("Mahnaz", new Double(123.22)); tm.put("Ayan", new Double(1378.00)); tm.put("Daisy", new Double(99.22)); tm.put("Qadir", new Double(-19.08)); // Get a set of the entries Set set = tm.entrySet(); // Get an iterator Iterator i = set.iterator(); // Display elements while(i.hasNext()) { Map.Entry me = (Map.Entry)i.next(); System.out.print(me.getKey() + ": "); System.out.println(me.getValue()); } System.out.println(); // Deposit 1000 into Zara's account double balance = ((Double)tm.get("Zara")).doubleValue(); tm.put("Zara", new Double(balance + 1000)); System.out.println("Zara's new balance: " + tm.get("Zara")); } }
这将产生以下结果:
输出
Ayan: 1378.0 Daisy: 99.22 Mahnaz: 123.22 Qadir: -19.08 Zara: 3434.34 Zara's new balance: 4434.34