Guava-multiset

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

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

マルチセットインターフェイスは、重複する要素を持つように「セット」を拡張し、セット内のそのような要素の発生に対処するためのさまざまなユーティリティメソッドを提供します。

インターフェイス宣言

以下は com.google.common.collect.Multiset <E> インターフェースの宣言です-

@GwtCompatible
public interface Multiset<E>
   extends Collection<E>

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

Sr.No Method & Description
1

boolean add(E element)

指定された要素の単一オカレンスをこのマルチセットに追加します。

2

int add(E element, int occurrences)

要素のオカレンスの数をこのマルチセットに追加します。

3

boolean contains(Object element)

このマルチセットに指定された要素が含まれているかどうかを判断します。

4

boolean containsAll(Collection<?> elements)

このマルチセットに、指定されたコレクションの各要素が少なくとも1つ含まれている場合、trueを返します。

5

int count(Object element)

このマルチセット内の要素の出現回数(要素のカウント)を返します。

6

Set<E> elementSet()

このマルチセットに含まれる個別の要素のセットを返します。

7

Set<Multiset.Entry<E>> entrySet()

Multiset.Entryインスタンスにグループ化されたこのマルチセットの内容のビューを返します。各インスタンスは、マルチセットの要素とその要素のカウントを提供します。

8

boolean equals(Object object)

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

9

int hashCode()

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

10

Iterator<E> iterator()

このコレクション内の要素の反復子を返します。

11

boolean remove(Object element)

このマルチセットが存在する場合、このマルチセットから指定された要素の単一のオカレンスを削除します。

12

int remove(Object element, int occurrences)

指定された要素の多数の出現をこのマルチセットから削除します。

13

boolean removeAll(Collection<?> c)

指定されたコレクションにも含まれるこのコレクションの要素をすべて削除します(オプションの操作)。

14

boolean retainAll(Collection<?> c)

指定されたコレクションに含まれるこのコレクション内の要素のみを保持します(オプションの操作)。

15

int setCount(E element, int count)

要素が必要な数になるように、要素の必要なオカレンスを追加または削除します。

16

boolean setCount(E element, int oldCount, int newCount)

setCount(Object、int)で説明されているように、要素に予想される現在のカウントがある場合、要素のカウントを条件付きで新しい値に設定します。

17

String toString()

オブジェクトの文字列表現を返します。

継承されるメソッド

このインターフェイスは、次のインターフェイスからメソッドを継承します-

  • java.util.Collection

マルチセットの例

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

GuavaTester.java

import java.util.Iterator;
import java.util.Set;

import com.google.common.collect.HashMultiset;
import com.google.common.collect.Multiset;

public class GuavaTester {

   public static void main(String args[]) {

     //create a multiset collection
      Multiset<String> multiset = HashMultiset.create();

      multiset.add("a");
      multiset.add("b");
      multiset.add("c");
      multiset.add("d");
      multiset.add("a");
      multiset.add("b");
      multiset.add("c");
      multiset.add("b");
      multiset.add("b");
      multiset.add("b");

     //print the occurrence of an element
      System.out.println("Occurrence of 'b' : "+multiset.count("b"));

     //print the total size of the multiset
      System.out.println("Total Size : "+multiset.size());

     //get the distinct elements of the multiset as set
      Set<String> set = multiset.elementSet();

     //display the elements of the set
      System.out.println("Set [");

      for (String s : set) {
         System.out.println(s);
      }

      System.out.println("]");

     //display all the elements of the multiset using iterator
      Iterator<String> iterator  = multiset.iterator();
      System.out.println("MultiSet [");

      while(iterator.hasNext()) {
         System.out.println(iterator.next());
      }

      System.out.println("]");

     //display the distinct elements of the multiset with their occurrence count
      System.out.println("MultiSet [");

      for (Multiset.Entry<String> entry : multiset.entrySet()) {
         System.out.println("Element: " + entry.getElement() + ", Occurrence(s): " + entry.getCount());
      }
      System.out.println("]");

     //remove extra occurrences
      multiset.remove("b",2);

     //print the occurrence of an element
      System.out.println("Occurence of 'b' : " + multiset.count("b"));
   }
}

結果を確認する

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

C:\Guava>javac GuavaTester.java

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

C:\Guava>java GuavaTester

結果をご覧ください。

Occurence of 'b' : 5
Total Size : 10
Set [
d
b
c
a
]
MultiSet [
d
b
b
b
b
b
c
c
a
a
]
MultiSet [
Element: d, Occurence(s): 1
Element: b, Occurence(s): 5
Element: c, Occurence(s): 2
Element: a, Occurence(s): 2
]
Occurence of 'b' : 3