强大的Guava中的新集合类型: Multiset, Multimap, BiMap, Table, ClassToInstanceMap, RangeSet, RangeMap等
一 Multiset
/**
* 新类型集合: Multiset: Multiset就是可以保存多个相同的对象,并且无序
* 占据了List和Set之间的一个灰色地带
* 其他实现: TreeMultiset LinkedHashMultiset
* ConcurrentHashMultiset
* ImmutableMultiset
*/
@Test
public void newList(){
HashMultiset<Integer> multiset = HashMultiset.create();
multiset.add(2,3);//添加指定个数的重复元素
multiset.count(2); //获取元素在集合中的个数
multiset.remove(2,2); //移除指定的个数元素
multiset.setCount(5,2); //和add相同
multiset.setCount(5,2,3); //修改集合中元素的个数,2个改为3个
//常见功能,统计每个字符出现的此数
String strWorld="wer|dffd|ddsa|dfd|dreg|de|dr|ce|ghrt|cf|gt|ser|tg|ghrt|cf|gt|" +
"ser|tg|gt|kldf|dfg|vcd|fg|gt|ls|lser|dfr|wer|dffd|ddsa|dfd|dreg|de|dr|" +
"ce|ghrt|cf|gt|ser|tg|gt|kldf|dfg|vcd|fg|gt|ls|lser|dfr";
HashMultiset<String> multisetStr = HashMultiset.create();
multisetStr.addAll(Arrays.asList(strWorld.split("\\|")));
multisetStr.elementSet().forEach(x->System.out.println(x+" :"+multisetStr.count(x)));
}
二 Multimap
/**
* Multimap 提供了一个方便地把一个键对应到多个值的数据结构
* ”键-单个值映射”的集合(例如:a -> 1 a -> 2 a ->4 b -> 3 c -> 5)
* 用于替代 Map<K, List<V>>或Map<K, Set<V>>这种结构
* 提供多种实现 ArrayListMultimap HashMultimap 等
*/
@Test
public void multiMapTest(){
Multimap<String, User> multimap = ArrayListMultimap.create();
for (int i = 1; i <= 5; i++) {
multimap.put("one",User.of().setAge(23).setName("用户"+i).setLevel(i));
}
for (int i = 1; i <= 5; i++) {
multimap.put("two",User.of().setAge(20).setName("用户"+i).setLevel(i));
}
multimap.containsKey("one"); //判断是否包含有key
multimap.size(); //所有元素个数
//转换为map数据结构
Map<String, Collection<User>> map = multimap.asMap();
multimap.remove("key",User.of());//移除key对应下指定的value
multimap.keys();//获取所有的key
multimap.values(); //获取所有的value
multimap.removeAll("one");//移除key对应的所有元素
multimap.replaceValues("two", Lists.newArrayList(User.of()));// 替换key对应的元素
}
三 BiMap
/**
* BiMap提供了一种新的集合类型,它提供了key和value的双向关联的数据结构
* 能非常方便的实现map<key,value>的转置要求,也就是value变为key,key变为value
* 保证值是唯一的,因此返回Set而不是普通的Collection
*/
@Test
public void biMapTest(){
BiMap<Integer, String> hashBiMap = HashBiMap.create();
hashBiMap.put(1,"用户1");
hashBiMap.put(2,"用户2");
hashBiMap.put(3,"用户3");
//键值转换
BiMap<String, Integer> inverseBiMap = hashBiMap.inverse();
inverseBiMap.entrySet().forEach(x->
System.out.println("key:"+x.getKey()+", value:"+x.getValue()));
//因为值唯一(需要翻转时候key唯一),所以添加时如果value存在抛异常,可使用forcePut强制替换键
// hashBiMap.put(4,"用户3"); IllegalArgumentException
hashBiMap.forcePut(4,"用户3"); //强制替换用户3的键为4
//根据kv进行消费返回结果
String compute = hashBiMap.compute(4, (x, y) -> x + y);
System.out.println(compute); // 4用户3
}
四 Table
/**
* Table是Guava提供的一个接口 Interface Table(R,C,V),
* 由rowKey(行)+columnKey(列)+value组成 ,它有两个支持所有类型的键:”行”和”列”
* 其实就是有了双键的Map
* 例如: 学生(rowkey)--课程(columkey)--成绩(value)
*/
@Test
public void tableTest(){
Table<String, String, Integer> hashBasedTable = HashBasedTable.create();
hashBasedTable.put("一班","数学",97);
hashBasedTable.put("二班","英语",85);
hashBasedTable.put("二班","语文",70);
hashBasedTable.get("一班", "数学"); //通过两个key获取value
hashBasedTable.columnKeySet(); //获取列key [数学, 英语, 语文]
hashBasedTable.rowKeySet();//获取行key [一班, 二班]
//获取所有行的set
hashBasedTable.cellSet().forEach(x->
System.out.println("rowKey:"+x.getRowKey()+
", columnKey:"+x.getColumnKey()+", value:"+x.getValue()));
hashBasedTable.row("二班"); //根据rowKey获取所有对应的columnKey和value的 map
hashBasedTable.column("数学"); //根据columnKey获取所有对应的rowKey和value 的 map
hashBasedTable.rowMap(); //获取rowKey对应的 列-value map
hashBasedTable.remove("一班","数学"); //移除元素
hashBasedTable.columnMap(); //获取columnKey对应的 rowKey-value map }
五 ClassToInstanceMap
/**
* ClassToInstanceMap是一种特殊的Map:它的键是类型,而值是符合键所指类型的对象
*/
@Test
public void classToInstanceMapTest(){
//可存放所有数字类型的map
ClassToInstanceMap<Number> numberDefaults= MutableClassToInstanceMap.create();
numberDefaults.putInstance(Integer.class, 1);
numberDefaults.putInstance(Double.class, 1.00);
numberDefaults.putInstance(BigDecimal.class, new BigDecimal("52"));
numberDefaults.put(Integer.class, 2);
numberDefaults.replace(Integer.class, 3); //修改
numberDefaults.getInstance(Integer.class); //获取value 3
//通过传入新值和旧值计算,修改旧值,例: 将Integer,class的值+3
numberDefaults.merge(Integer.class,2,(x,y)->x.intValue()+y.intValue());
numberDefaults.forEach((x,y)-> System.out.println(x+","+y));
/**
* class java.lang.Double,1.0
* class java.math.BigDecimal,52
* class java.lang.Integer,5
*/ }
六 RangeSet
/**
* RangeSet描述了一组不相连的、非空的区间。
* 当把一个区间添加到可变的RangeSet时,所有相连的区间会被合并,空区间会被忽略
*/
@Test
public void rangeSetTest(){
RangeSet<Comparable<?>> treeRangeSet = TreeRangeSet.create();
treeRangeSet.add(Range.closed(1,10));
//连续区间会被合并 [15,22]
treeRangeSet.add(Range.closedOpen(15,20));
treeRangeSet.add(Range.closed(18,22));
treeRangeSet.remove(Range.closed(2,8)); //移除.,会把区间分割
//遍历所有区间
treeRangeSet.asRanges().forEach(x-> System.out.println(x)); // 返回一个目前所有区间里的最小值到最大值的区间
treeRangeSet.span();// [1..22]
//获取互补区间
treeRangeSet.complement();//[(-∞..1), (10..15), (22..+∞)]
treeRangeSet.contains(14); //是否包含此元素 false
//返回元素所在的区间,不包含返回null
treeRangeSet.rangeContaining(14);
// 是否包含某个区间
treeRangeSet.encloses(Range.closed(1, 10)); //true
//返回交集
treeRangeSet.subRangeSet(Range.closed(1, 4));
}
七 RangeMap
/**
* RangeMap描述了”不相交的、非空的区间”到特定值的映射。即 key是区间, value是值的map
* 和RangeSet不同,RangeMap不会合并相邻的映射,即便相邻的区间映射到相同的值
*/
@Test
public void rangeMap(){
RangeMap<Integer, String> rangeMap = TreeRangeMap.create();
rangeMap.put(Range.closed(1, 10), "foo");
rangeMap.put(Range.open(3, 6), "bar");
rangeMap.put(Range.open(10, 20), "foo");
rangeMap.remove(Range.closed(5, 11));
//根据区间里的任意值获取value
rangeMap.get(1); //foo
//获取map视图进行迭代
rangeMap.asMapOfRanges().forEach((x,y)-> {
System.out.println(x); // [1..3]
System.out.println(y); // foo
});
}
rangermap很多用法和rangeSet一样的
/**
* RangeMap描述了”不相交的、非空的区间”到特定值的映射。即 key是区间, value是值的map
* 和RangeSet不同,RangeMap不会合并相邻的映射,即便相邻的区间映射到相同的值
*/
@Test
public void rangeMap(){
RangeMap<Integer, String> rangeMap = TreeRangeMap.create();
rangeMap.put(Range.closed(1, 10), "foo");
rangeMap.put(Range.open(3, 6), "bar");
rangeMap.put(Range.open(10, 20), "foo");
rangeMap.remove(Range.closed(5, 11));
//根据区间里的任意值获取value
rangeMap.get(1); //foo
//获取map视图进行迭代
rangeMap.asMapOfRanges().forEach((x,y)-> {
System.out.println(x); // [1..3]
System.out.println(y); // foo
});
}
强大的Guava中的新集合类型: Multiset, Multimap, BiMap, Table, ClassToInstanceMap, RangeSet, RangeMap等的更多相关文章
- 004-guava 集合-新增集合类型-MultiSet, MultiMap, BiMap , Table, ClassToInstanceMap, RangeSe, RangeMap等
一.概述 Guava引入了很多JDK没有的.但明显有用的新集合类型.这些新类型是为了和JDK集合框架共存,而没有往JDK集合抽象中硬塞其他概念.作为一般规则,Guava集合非常精准地遵循了JDK接口契 ...
- [Google Guava]学习--新集合类型Multiset
Guava提供了一个新集合类型Multiset,它可以多次添加相等的元素,且和元素顺序无关.Multiset继承于JDK的Cllection接口,而不是Set接口. Multiset主要方法介绍: a ...
- [Guava学习笔记]Collections: 不可变集合, 新集合类型
我的技术博客经常被流氓网站恶意爬取转载.请移步原文:http://www.cnblogs.com/hamhog/p/3843386.html,享受整齐的排版.有效的链接.正确的代码缩进.更好的阅读体验 ...
- Guava集合--新集合类型
Guava引入了很多JDK没有的.但我们发现明显有用的新集合类型.这些新类型是为了和JDK集合框架共存,而没有往JDK集合抽象中硬塞其他概念.作为一般规则,Guava集合非常精准地遵循了JDK接口契约 ...
- guava -- 新集合类型
Guava引入了很多JDK没有的.但有用的新集合类型.这些新类型是为了和JDK集合框架共存,而没有往JDK集合抽象中硬塞其他概念. 作为一般规则,Guava集合非常精准地遵循了JDK接口契约. 1. ...
- Guava源码学习(四)新集合类型
基于版本:Guava 22.0 Wiki:New collection types 0. 简介 Guava提供了很多好用的集合工具,比如Multiset和BiMap,本文介绍了这些新集合类型的使用方式 ...
- Guava学习笔记:Guava新增集合类型-Multiset
Guava引进了JDK里没有的,但是非常有用的一些新的集合类型.所有这些新集合类型都能和JDK里的集合平滑集成.Guava集合非常精准地实现了JDK定义的接口.Guava中定义的新集合有: Multi ...
- Guava新增集合类型-Multiset
Guava新增集合类型-Multiset Guava引进了JDK里没有的,但是非常有用的一些新的集合类型.所有这些新集合类型都能和JDK里的集合平滑集成.Guava集合非常精准地实现了JDK定义的接口 ...
- [Google Guava]学习--新集合类型Multimap
每个有经验的Java程序员都在某处实现过Map<K, List<V>>或Map<K, Set<V>>,并且要忍受这个结构的笨拙. 假如目前有个需求是给两 ...
随机推荐
- vue-cli项目中使用axios
前言 前后端数据交互中,我们使用最多的就是jQuey中的ajax进行数据交互,但是随着大前端日益的扩大,越来越多的库和框架也渐渐的出现在前端开发人员面前,而本编博客需要介绍的就是在vue-cli项目中 ...
- The fifth day of Crawler learning
使用mongoDB 下载地址:https://www.mongodb.com/dr/fastdl.mongodb.org/win32/mongodb-win32-x86_64-2008plus-ssl ...
- $HDU1846\ Brave\ Game$ 博弈论
正解:博弈论 解题报告: 传送门! 巴什博奕板子题鸭$QwQ$ 就有个结论,是说当$(m+1)\mid n$时先手必败,否则必胜 这个瞎证明一下就能出来 就考虑当$(m+1)\mid 1$时,若先手取 ...
- 在 Win7、Win10 家庭版中启用组策略(gpedit.msc)
Windows 家庭版并没有组策略,对于计算机维护.优化和设置非常不方便.使用以下批处理可以在不安装专业版.旗舰版的情况下启用组策略. 一.新建一个批处理脚本 1 @echo off 2 3 push ...
- spring cloud 微服务之 -- 配置文件拆分之道
0-前言 在spring cloud微服务架构中,基本上每个拆分的微服务都会部署多个运行实例,这些运行实例,配置基本都是一样的,不同的是少数配置,比如端口,而这些不同的配置又是必不可少的 那我们怎么来 ...
- 洛谷P2657 [SCOI2009]windy数 题解 数位DP
题目链接:https://www.luogu.com.cn/problem/P2657 题目大意:找区间 \([A,B]\) 范围内 不含前导零 且 相邻两个数字之差至少为2 的正整数的个数. 题目分 ...
- 「洛谷P2397」 yyy loves Maths VI (mode) 解题报告
P2397 yyy loves Maths VI (mode) 题目背景 自动上次redbag用加法好好的刁难过了yyy同学以后,yyy十分愤怒.他还击给了redbag一题,但是这题他惊讶的发现自己居 ...
- python django 基本环境配置
创建虚拟环境: python -m venv django启动虚拟环境: .\venv\Scripts\activate下载django: pip install django查看django命令: ...
- cometoj 茶颜悦色|扫描线+懒惰标记
传送门 题目描述 茶颜悦色也太好喝了!鸡尾酒在长沙的各种茶颜悦色的店铺中流连忘返.他发现长沙有炒鸡多的茶颜悦色店,走两步就能遇到一家. “方圆一公里能有十家茶颜悦色!”鸡尾酒感叹了起来. 于是他想到了 ...
- Linux学习_菜鸟教程_4
Linux远程登录 已经了解了登录流程,学会了用SecureCRT进行操作 Linux文件基本属性 Linux为保护系统安全,对不同的用户,开放不同的文件访问权限. 在linux中,我们可以使用ll或 ...