Guava-Map

举报
西魏陶渊明 发表于 2022/09/25 02:29:31 2022/09/25
【摘要】 # 一、简介 Guava 是一组来自 Google 的核心 Java 库,其中包括新的集合类型(例如 multimap 和 multiset)、不可变集合、图形库以及用于并发、I/O、散列、缓存、原语、字符串等的实用程序!它广泛用于 Google 内部的大多数 Java 项目,也被许多其他公司广泛使用。 API 非常的简单,...

# 一、简介

Guava 是一组来自 Google 的核心 Java 库,其中包括新的集合类型(例如 multimap 和 multiset)、不可变集合、图形库以及用于并发、I/O、散列、缓存、原语、字符串等的实用程序!它广泛用于 Google 内部的大多数 Java 项目,也被许多其他公司广泛使用。

API 非常的简单,我们可以非常轻松的使用,来封装成我们业务中自己的组件。

# 二、依赖


        <dependency>
               <groupId>com.google.guava</groupId>
               <artifactId>guava</artifactId>
               <version>30.1.1-jre</version>
           </dependency>
    
   
1 2 3 4 5

# 三、使用介绍

# 3.1 Table 双键 Map

java中的Map只允许有一个key和一个value存在,但是guava中的Table允许一个value存在两个key。Table中的两个key分别被称为rowKey和columnKey,也就是行和列。


        Table<String,String,Integer> table= HashBasedTable.create();
        //存放元素
        table.put("Hydra", "Jan", 20);
        table.put("Hydra", "Feb", 28);
        table.put("Trunks", "Jan", 28);
        table.put("Trunks", "Feb", 16);
        //取出元素
        Integer dayCount = table.get("Hydra", "Feb");
    
   
1 2 3 4 5 6 7 8

# 3.2 BiMap 双向Map

在普通Map中,如果要想根据value查找对应的key,没什么简便的办法,无论是使用for循环还是迭代器,都需要遍历整个Map。 而guava中的BiMap提供了一种key和value双向关联的数据结构。


        HashBiMap<String, String> biMap = HashBiMap.create();
        biMap.put("Hydra","Programmer");
        biMap.put("Tony","IronMan");
        biMap.put("Thanos","Titan");
        //使用key获取value
        System.out.println(biMap.get("Tony"));
        BiMap<String, String> inverse = biMap.inverse();
        //使用value获取key
        System.out.println(inverse.get("Titan"));
    
   
1 2 3 4 5 6 7 8 9

注意: 反转后的BiMap并不是一个新的对象,它实现了一种视图的关联,所以对反转后的BiMap执行的所有操作会作用于原先的BiMap上。


        HashBiMap<String, String> biMap = HashBiMap.create();
        biMap.put("Hydra","Programmer");
        biMap.put("Tony","IronMan");
        biMap.put("Thanos","Titan");
        BiMap<String, String> inverse = biMap.inverse();
        inverse.put("IronMan","Stark");
        System.out.println(biMap);
    
   
1 2 3 4 5 6 7

对反转后的BiMap中的内容进行了修改后,再看一下原先BiMap中的内容:

{Hydra=Programmer, Thanos=Titan, Stark=IronMan}

   
1

可以看到,原先值为IronMan时对应的键是Tony,虽然没有直接修改,但是现在键变成了Stark。

# 3.3 Multimap 多值Map

java中的Map维护的是键值一对一的关系,如果要将一个键映射到多个值上,那么就只能把值的内容设为集合形式,而在guava中可以使用如下:


        Multimap<String, Integer> multimap = ArrayListMultimap.create();
        multimap.put("day",1);
        multimap.put("day",2);
        multimap.put("day",8);
        multimap.put("month",3);
    
   
1 2 3 4 5

打印这个Multimap的内容,可以直观的看到每个key对应的都是一个集合:

{month=[3], day=[1, 2, 8]}
   
1

# 3.4 RangeMap 范围Map

先看一个例子,假设我们要根据分数对考试成绩进行分类,那么代码中就会出现这样丑陋的if-else:


        public static String getRank(int score){
           if (0<=score && score<60)
               return "fail";
           else if (60<=score && score<=90)
               return "satisfactory";
           else if (90<score && score<=100)
               return "excellent";
           return null;
        }
    
   
1 2 3 4 5 6 7 8 9

而guava中的RangeMap描述了一种从区间到特定值的映射关系,让我们能够以更为优雅的方法来书写代码。下面用RangeMap改造上面的代码并进行测试:


        RangeMap<Integer, String> rangeMap = TreeRangeMap.create();
        rangeMap.put(Range.closedOpen(0,60),"fail");
        rangeMap.put(Range.closed(60,90),"satisfactory");
        rangeMap.put(Range.openClosed(90,100),"excellent");
        System.out.println(rangeMap.get(59));
        System.out.println(rangeMap.get(60));
        System.out.println(rangeMap.get(90));
        System.out.println(rangeMap.get(91));
    
   
1 2 3 4 5 6 7 8

在上面的代码中,先后创建了[0,60)的左闭右开区间、[60,90]的闭区间、(90,100]的左开右闭区间,并分别映射到某个值上。运行结果打印:


        fail
        satisfactory
        satisfactory
        excellent
    
   
1 2 3 4

# 3.5 ClassToInstanceMap 实例Map

ClassToInstanceMap是一个比较特殊的Map,它的键是Class,而值是这个Class对应的实例对象。先看一个简单使用的例子,使用putInstance方法存入对象


        ClassToInstanceMap<Object> instanceMap = MutableClassToInstanceMap.create();
        User user=new User("Hydra",18);
        Dept dept=new Dept("develop",200);
        instanceMap.putInstance(User.class,user);
        instanceMap.putInstance(Dept.class,dept);
    
   
1 2 3 4 5

那么,使用ClassToInstanceMap这种方式有什么好处呢?

最明显的就是在取出对象时省去了复杂的强制类型转换,避免了手动进行类型转换的错误。 所以,如果你想缓存对象,又不想做复杂的类型校验,那么使用方便的ClassToInstanceMap就可以了。

文章来源: springlearn.blog.csdn.net,作者:西魏陶渊明,版权归原作者所有,如需转载,请联系作者。

原文链接:springlearn.blog.csdn.net/article/details/125858133

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。