Google guava 最佳实践 学习指南之08 `BiMap`(双向映射)

guava 最佳实践 学习指南

Google Guava 库中的 BiMap(双向映射)是一种特殊的映射类型,它维护了映射的反向视图,并确保不存在重复值,且始终可以安全地使用值获取对应的键。以下是关于 Guava BiMap 的一些介绍和用法:

1. 概述

BiMap(或称为"双向映射")是一种特殊的映射类型,它允许通过键查找值,同时也可以通过值查找键。这意味着在 BiMap 中,不仅键是唯一的,值也必须是唯一的。BiMap 接口扩展了 Map 接口,并添加了一些方法来提供反向视图。

2. BiMap 的实现类

Guava 提供了几种 BiMap 的实现:

  • HashBiMap :基于哈希表的双向映射实现。它提供了常数时间的 containsKeygetput 操作(假设哈希函数是完美的)。由于其基于哈希表,它不保证元素的顺序。
  • EnumBiMap :一种特殊的 BiMap,它要求键和值都是枚举类型。这种实现类型安全和高效,适用于键和值都是已知枚举值的情况。
  • ImmutableBiMap :不可修改的 BiMap,遵循构建器模式。

3. BiMap 的常用方法

除了继承自 Map 接口的方法外,BiMap 还添加了一些特有的方法:

  • inverse() :返回一个视图,其中的键和值与原 BiMap 中的值和键相反。注意,返回的是视图,对返回映射的更改将反映在原映射上,反之亦然。
  • forcePut(K key, V value) :类似于 put 方法,但如果键或值已经存在,则会抛出 IllegalArgumentException
  • containsValue(Object value) :检查 BiMap 中是否包含指定的值。

4. BiMap 的用法示例

以下是一个简单的示例,展示如何使用 Guava 的 HashBiMap 实现 BiMap 接口,并演示了它的多种方法:

java 复制代码
import com.google.common.collect.BiMap;
import com.google.common.collect.HashBiMap;

public class BiMapExample {
    public static void main(String[] args) {
        // 创建一个空的HashBiMap
        BiMap<String, Integer> biMap = HashBiMap.create();
        // 向BiMap中添加元素
        biMap.put("One", 1);
        biMap.put("Two", 2);
        biMap.put("Three", 3);
        // 使用get方法通过键获取值
        System.out.println("Two maps to: " + biMap.get("Two")); // 输出: Two maps to: 2
        // 使用get方法通过值获取键(使用inverse()方法)
        System.out.println("2 maps to: " + biMap.inverse().get(2)); // 输出: 2 maps to: Two
        // 检查BiMap中是否包含某个键
        System.out.println("Does the map contain key 'One'? " + biMap.containsKey("One")); // 输出: Does the map contain key 'One'? true
        // 检查BiMap中是否包含某个值
        System.out.println("Does the map contain value 2? " + biMap.containsValue(2)); // 输出: Does the map contain value 2? true
    }
}

这个示例展示了如何创建 BiMap,添加元素,以及如何通过键和值进行查询。

相关推荐
小刘不想改BUG4 分钟前
LeetCode LCR 010 和为 K 的子数组 (Java)
java·算法·leetcode
MeyrlNotFound5 分钟前
(二十一)Java集合框架源码深度解析
java·开发语言
TNTLWT9 分钟前
Qt功能区:Ribbon使用
开发语言·qt·ribbon
正在走向自律14 分钟前
2025年、2024年最新版IntelliJ IDEA下载安装过程(含Java环境搭建+Maven下载及配置)
java·jvm·jdk·maven·intellij-idea
不会就选C.14 分钟前
【开源分享】健康饮食管理系统(双端+论文)
java·spring boot·开源·毕业设计
永远有多远.15 分钟前
【高频面试题】LRU缓存
java·缓存·面试
Ten peaches16 分钟前
Selenium-Java版(环境安装)
java·前端·selenium·自动化
Ronin30522 分钟前
【C++】18.二叉搜索树
开发语言·数据结构·c++
Susea&23 分钟前
初始C++:类和对象(中)
c语言·开发语言·c++
编程、小哥哥32 分钟前
Java求职者面试:从Spring Boot到微服务的技术点解析
java·spring boot·redis·微服务·spring security·高并发·面试题