Guava-multimap

提供:Dev Guides
移動先:案内検索

グアバ-マルチマップインターフェイス

MultimapインターフェイスはMapを拡張して、キーを一度に複数の値にマップできるようにします。

インターフェイス宣言

以下は com.google.common.collect.Multimap <K、V> インターフェースの宣言です-

@GwtCompatible
public interface Multimap<K,V>

インターフェースメソッド

Sr.No Method & Description
1

Map<K,Collection<V>> asMap()

このマルチマップのビューを、個別のキーからそのキーに関連付けられた値の空でないコレクションへのマップとして返​​します。

2

void clear()

マルチマップからすべてのキーと値のペアを削除し、空のままにします。

3

boolean containsEntry(Object key, Object value)

このマルチマップにキーと値のキーと値のペアが少なくとも1つ含まれている場合、trueを返します。

4

boolean containsKey(Object key)

このマルチマップにキーとのキーと値のペアが少なくとも1つ含まれている場合、trueを返します。

5

boolean containsValue(Object value)

このマルチマップに値を持つキーと値のペアが少なくとも1つ含まれている場合、trueを返します。

6

Collection<Map.Entry<K,V>> entries()

このマルチマップに含まれるすべてのキーと値のペアのビューコレクションをMap.Entryインスタンスとして返します。

7

boolean equals(Object obj)

指定されたオブジェクトとこのマルチマップが等しいかどうかを比較します。

8

Collection<V> get(K key)

このマルチマップのキーに関連付けられている値がある場合、その値のビューコレクションを返します。

9

int hashCode()

このマルチマップのハッシュコードを返します。

10

boolean isEmpty()

このマルチマップにキーと値のペアが含まれていない場合にtrueを返します。

11

Multiset<K> keys()

このマルチマップ内の各キーと値のペアのキーを含むビューコレクションを、重複を折りたたむことなく返します。

12

Set<K> keySet()

このマルチマップに含まれるすべての異なるキーのビューコレクションを返します。

13

boolean put(K key, V value)

このマルチマップにキーと値のペアを格納します。

14

boolean putAll(K key, Iterable<? extends V> values)

同じキーkeyをすべて使用して、値ごとにこのマルチマップにキーと値のペアを格納します。

15

boolean putAll(Multimap<? extends K,? extends V> multimap)

multimap.entries()によって返された順序で、このマルチマップにマルチマップのすべてのキーと値のペアを格納します。

16

boolean remove(Object key, Object value)

存在する場合、このマルチマップからキーと値を持つ単一のキーと値のペアを削除します。

17

Collection<V> removeAll(Object key)

キーに関連付けられているすべての値を削除します。

18

Collection<V> replaceValues(K key, Iterable<? extends V> values)

同じキーを持つ値のコレクションを保存し、そのキーの既存の値を置き換えます。

19

int size()

このマルチマップ内のキーと値のペアの数を返します。

20

Collection<V> values()

このマルチマップに含まれる各キーと値のペアからの値を含むビューコレクションを返します。重複を折りたたみません(そのため、values()。size()== size())。

マルチマップの例

たとえば、* C:/> Guava。*で選択したエディターを使用して、次のJavaプログラムを作成します。

GuavaTester.java

import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;

import com.google.common.collect.ArrayListMultimap;
import com.google.common.collect.Multimap;

public class GuavaTester {
   public static void main(String args[]) {

      GuavaTester tester = new GuavaTester();
      Multimap<String,String> multimap = tester.getMultimap();

      List<String> lowerList = (List<String>)multimap.get("lower");
      System.out.println("Initial lower case list");
      System.out.println(lowerList.toString());

      lowerList.add("f");
      System.out.println("Modified lower case list");
      System.out.println(lowerList.toString());

      List<String> upperList = (List<String>)multimap.get("upper");
      System.out.println("Initial upper case list");
      System.out.println(upperList.toString());

      upperList.remove("D");
      System.out.println("Modified upper case list");
      System.out.println(upperList.toString());

      Map<String, Collection<String>> map = multimap.asMap();
      System.out.println("Multimap as a map");

      for (Map.Entry<String,  Collection<String>> entry : map.entrySet()) {
         String key = entry.getKey();
         Collection<String> value =  multimap.get("lower");
         System.out.println(key + ":" + value);
      }

      System.out.println("Keys of Multimap");
      Set<String> keys =  multimap.keySet();

      for(String key:keys) {
         System.out.println(key);
      }

      System.out.println("Values of Multimap");
      Collection<String> values = multimap.values();
      System.out.println(values);
   }

   private Multimap<String,String> getMultimap() {

     //Map<String, List<String>>
     //lower -> a, b, c, d, e
     //upper -> A, B, C, D

      Multimap<String,String> multimap = ArrayListMultimap.create();

      multimap.put("lower", "a");
      multimap.put("lower", "b");
      multimap.put("lower", "c");
      multimap.put("lower", "d");
      multimap.put("lower", "e");

      multimap.put("upper", "A");
      multimap.put("upper", "B");
      multimap.put("upper", "C");
      multimap.put("upper", "D");

      return multimap;
   }
}

結果を確認する

次のように javac コンパイラを使用してクラスをコンパイルします-

C:\Guava>javac GuavaTester.java

GuavaTesterを実行して結果を確認します。

C:\Guava>java GuavaTester

結果をご覧ください。

Initial lower case list
[a, b, c, d, e]
Modified lower case list
[a, b, c, d, e, f]
Initial upper case list
[A, B, C, D]
Modified upper case list
[A, B, C]
Multimap as a map
upper:[a, b, c, d, e, f]
lower:[a, b, c, d, e, f]
Keys of Multimap
upper
lower
Values of Multimap
[a, b, c, d, e, f, A, B, C]