How is ArrayListMultimap different from LinkedListMultimap?

后端 未结 1 562
甜味超标
甜味超标 2021-02-06 09:56

So, I was just reading the javadoc for ArrayListMultimap and LinkedListMultimap so as to understand how to use them and I came to know that both suppor

1条回答
  •  旧时难觅i
    2021-02-06 10:07

    It's in the docs... and in the code. Basically besides one difference you've already seen (List implementation choice), they also use a different Map implementation. So:

    • ArrayListMultimap uses HashMap for map and ArrayList cor collection, which means that iteration order of such methods as entries(), asMap().keySet() or asMap.entrySet() is undefined. It's plain and simple implementation of ListMultimap and you should start with this one.
    • LinkedListMultimap uses LinkedList for collection and specialized data structure (custom linked list) to maintain iteration order of methods mentioned above:

      Order is maintained using a linked list containing all key-value pairs. In addition, a series of disjoint linked lists of "siblings", each containing the values for a specific key, is used to implement ValueForKeyIterator in constant time.

      Additionally it uses few other structures to maintain "linked list"-like behavior:

      private transient Node head; // the head for all keys
      private transient Node tail; // the tail for all keys
      private transient Multiset keyCount; // the number of values for each key
      private transient Map> keyToKeyHead; // the head for a given key
      private transient Map> keyToKeyTail; // the tail for a given key
      

    Also, memory footprint is a implication of backing collections used in these Multimap implementations - see this comparision (may not be 100% up to date).


    Personally, when I need efficient, mutable ListMultimap with defined iteration order of keys, I use "custom" ListMultimap (created with MultimapBuilder, which is in Guava since v16.0):

    ListMultimap treeListMultimap = 
        MultimapBuilder.linkedHashKeys().arrayListValues().build();
    

    Before v16.0 creating custom Multimaps was more verbose (using Multimaps.newListMultimap):

    /**
     * Creates {@link ListMultimap} preserving insertion order of keys and values 
     * (it's backed by {@link LinkedHashMap} and {@link ArrayList}).
     */
    public static  ListMultimap newLinkedArrayListMultimap() {
      return Multimaps.newListMultimap(
          Maps.>newLinkedHashMap(),
          new Supplier>() {
              @Override
              public List get() {
                return Lists.newArrayList();
              }
          });
    }
    

    0 讨论(0)
提交回复
热议问题