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,添加元素,以及如何通过键和值进行查询。

相关推荐
竹言笙熙9 分钟前
Polarctf2025夏季赛 web java ez_check
java·学习·web安全
写bug写bug22 分钟前
手把手教你使用JConsole
java·后端·程序员
异常君24 分钟前
Java 中 try-catch 的性能真相:全面分析与最佳实践
java·面试·代码规范
程序员清风1 小时前
阿里二面:Kafka 消费者消费消息慢(10 多分钟),会对 Kafka 有什么影响?
java·后端·面试
幼稚园的山代王1 小时前
Prompt Enginering(提示工程)先进技术
java·人工智能·ai·chatgpt·langchain·prompt
周某某~1 小时前
二.单例模式‌
java·单例模式·设计模式
摸鱼仙人~1 小时前
深入理解Java单例模式:确保类只有一个实例
java·javascript·单例模式
SteveDraw1 小时前
C++动态链接库封装,供C#/C++ 等编程语言使用——C++动态链接库概述(总)
开发语言·c++·c#·封装·动态链接库
十五年专注C++开发2 小时前
设计模式之单例模式(二): 心得体会
开发语言·c++·单例模式·设计模式
hstar95272 小时前
三十五、面向对象底层逻辑-Spring MVC中AbstractXlsxStreamingView的设计
java·后端·spring·设计模式·架构·mvc