guava中Multimap、HashMultimap用法小结
作者:艾米莉Emily
在介绍Multimap之前我们先说一下Map,Map是一个key、value类型的键值对集合,集合中key不可以重复,但value可以重复,如果我们想在Map集合中存入一个相同的key,不同的value值得时候就必须使用 Map<Integer,,list<Object>>Map<Integer,List<Object>>模式来存数据,这样做很麻烦,而且编程效率又很低;
1. 现在我们来介绍一种更高效的集合Multimap
它可以很简单的实现上面我们所说的功能,先看下Multimap接口的源码
@GwtCompatible public interface Multimap<K, V> { //返回Multimap集合的key、value pair的数量 int size(); //判断Multimap是否包含key、value pair boolean isEmpty(); //判断Multimap中是否包含指定key的value值 boolean containsKey(@Nullable Object key); //判断Multimap中是否包含指定value的key boolean containsValue(@Nullable Object value); //判断Multimap中是否包含指定的key-value pair的数据 boolean containsEntry(@Nullable Object key, @Nullable Object value); //将数据加入到Multimap中 boolean put(@Nullable K key, @Nullable V value); //删除Multimap中指定key-value pair boolean remove(@Nullable Object key, @Nullable Object value); //将指定的key-集合数据加入Multimap中 boolean putAll(@Nullable K key, Iterable<? extends V> values); //将指定的Multimap和当前的Multimap合并 boolean putAll(Multimap<? extends K, ? extends V> multimap); //替换指定key的value Collection<V> replaceValues(@Nullable K key, Iterable<? extends V> values); //删除Imultimap中的指定key数据 Collection<V> removeAll(@Nullable Object key); //清空Imultimap中的数据 void clear(); //获取指定key的值 Collection<V> get(@Nullable K key); //获取所有的key集合 Set<K> keySet(); Multiset<K> keys(); Collection<V> values(); Collection<Map.Entry<K, V>> entries(); Map<K, Collection<V>> asMap(); @Override boolean equals(@Nullable Object obj); @Override int hashCode(); }
Multimap接口的实现类HashMultimap使用方法详解
- 创建HashMultimap对象
Multimap<Integer, Integer> map = HashMultimap.<Integer, Integer>create(); map.put(1, 2); map.put(1, 2); map.put(1, 3); map.put(1, 4); map.put(2, 3); map.put(3, 3); map.put(4, 3); map.put(5, 3); System.out.println(map);
{1=[4, 2, 3], 2=[3], 3=[3], 4=[3], 5=[3]}
从上面的结果集可以看出,key不可以重复,相同key的key-value pair 的value值是放在同一个数组中,相同的value会去重。
- 常用的方法示例
//判断集合中是否存在key-value为指定值得元素 System.out.println(map.containsEntry(1, 2)); System.out.println(map.containsEntry(1, 6)); //获取key为1的value集合 Collection<Integer> list = map.get(1); System.out.println(list); //返回集合中所有key的集合,重复的key将会用key * num的方式来表示 Multiset<Integer> set = map.keys(); System.out.println(set); //返回集合中所有不重复的key的集合 Set<Integer> kset = map.keySet(); System.out.println(kset);
true false [4, 2, 3] [1 x 3, 2 x 2, 3, 4, 5] [1, 2, 3, 4, 5]
replaceValues替换Multimap中指定key的值
Collection<Integer> coll = map.replaceValues(1, Arrays.asList(1,7,8,9,10)); System.out.println(coll); System.out.println(map);
[4, 2, 3] {1=[8, 9, 1, 10, 7], 2=[4, 3], 3=[3], 4=[3], 5=[3]}
replaceValues方法会替换掉key的value值,并且返回之前对应的值。
2. ImmutableMultimap不可变集合
ImmutableMultimap中提供了三个主要的静态方法of、builder、copyof;
//创建一个静态不可变的Multimap对象 Multimap<Integer, Integer> map = ImmutableMultimap.<Integer, Integer>of(); Multimap<Integer, Integer> map1 = ImmutableMultimap.<Integer, Integer>builder().build(); //从另外一个集合中复制数据元素到Multimap对象中 Multimap<Integer, Integer> map2 = ImmutableMultimap.copyOf(map);
3.LinkedHashMultimap实现类
LinkedHashMultimap实现类与HashMultimap类的实现方法一样,唯一的区别是LinkedHashMultimap保存了记录的插入顺序,在使用Iterator循环遍历的时候先得到的肯定是先放入Multimap中的数据。
Multimap<Integer, Integer> map = LinkedHashMultimap.<Integer, Integer>create(); map.putAll(4, Arrays.asList(5,3,4,2,1,56)); map.putAll(3, Arrays.asList(3,4,2,6,8,7)); map.put(1, 2); System.out.println(map);
运行结果是:
{4=[5, 3, 4, 2, 1, 56], 3=[3, 4, 2, 6, 8, 7], 1=[2]}
4.TreeMultimap实现类
TreeMultimap类继承成了Multimap接口,它的所有方法跟HashMultimap一样,但是有一点不同的是该类实现了SortedSetMultimap接口,该接口会将存入的数据按照自然排序,默认是升序。
Multimap<Integer, Integer> map = TreeMultimap.<Integer, Integer>create(); map.putAll(4, Arrays.asList(5,3,4,2,1,56)); map.putAll(3, Arrays.asList(3,4,2,6,8,7)); map.put(1, 2); System.out.println(map);
返回的结果是:
{1=[2], 3=[2, 3, 4, 6, 7, 8], 4=[1, 2, 3, 4, 5, 56]}
Multimap接口的实现类不仅仅只有HashMultimap、TreeMultimap、LinkedHashMultimap、ImmutableMultimap这几种,还有其它的实现类,我会在以后的学习过程中详解。
到此这篇关于guava中Multimap、HashMultimap使用详解的文章就介绍到这了,更多相关guava中Multimap、HashMultimap使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!