zoukankan      html  css  js  c++  java
  • Guava包学习-Multimap

    它和上一章的MultiSet的继承结果很相似,只不过在上层的接口是Multimap不是Multiset。

    Multimap的特点其实就是可以包含有几个重复Key的value,你可以put进入多个不同value但是相同的key,但是又不是让后面覆盖前面的内容。

    Guava中有很多multimap的变种,其实就是普通的map变种一样,这里不做详细解释,用的是拿出来就成了。先测试一下multimap的特性:

    public void testMultimap(){
            HashMultimap<Integer, Integer> map = HashMultimap.create();
            map.put(1, 2);
            map.put(1, 3);
            map.put(1, 2);
            map.put(2, 3);
            map.put(4, 2);
            map.put(4, 3);
            map.put(4, 2);
            map.put(4, 3);
            System.out.println(map.toString());
        }
    {1=[2, 3], 2=[3], 4=[2, 3]}

    其实它会把相同key和value的值给覆盖起来,但是相同的key又可以保留不同的value。因为它的entry的实现是一个set,set会对相同的Entry<K,V>进行去重,所以会有这种情况。

    另外就是它提供了一replaceValues的方法,替换某个key对应的values:

      @Override
      public Collection<V> replaceValues(@Nullable K key, Iterable<? extends V> values) {
        Iterator<? extends V> iterator = values.iterator();
        if (!iterator.hasNext()) {
          return removeAll(key);
        }
    
        // TODO(lowasser): investigate atomic failure?
        Collection<V> collection = getOrCreateCollection(key);
        Collection<V> oldValues = createCollection();
        oldValues.addAll(collection);
    
        totalSize -= collection.size();
        collection.clear();
    
        while (iterator.hasNext()) {
          if (collection.add(iterator.next())) {
            totalSize++;
          }
        }
    
        return unmodifiableCollectionSubclass(oldValues);
      }

    通过迭代values,对于values的集合进行去除,然后塞入新的值:

        map.replaceValues(1, Lists.newArrayList(4,5));
        System.out.println(map.toString());
      {1=[4, 5], 2=[3], 4=[2, 3]}

    Multimap的其它变种,和名字中的含义一样,各位适用于不同情况,只要在使用的时候择优选择即可:

    1.ArrayListMultimap:

    2.ForwardingMultimap:

    3.HashMultimap:

    4.ImmutableListMultimap:

    5.ImmutableMultimap:

    6.ImmutableSetMultimap:

    7.LinkedHashMultimap:

    8.LinkedListMultimap:

    9.TreeMultimap。

  • 相关阅读:
    Intersecting Lines (计算几何基础+判断两直线的位置关系)
    Morley's Theorem (计算几何基础+向量点积、叉积、旋转、夹角等+两直线的交点)
    TOYS(计算几何基础+点与直线的位置关系)
    Berland National Library
    PAT L2-017. 人以群分
    6.9服务与主机之间的映射
    第六章 部署
    5.12.1再试一次
    第5章 分解单块系统
    4.14.6 —种混合方式
  • 原文地址:https://www.cnblogs.com/congsg2016/p/5121551.html
Copyright © 2011-2022 走看看