Interfejs ConcurrentNavigableMap

Interfejs java.util.concurrent.ConcurrentNavigableMap jest podinterfejsem interfejsu ConcurrentMap i obsługuje operacje NavigableMap, a także rekurencyjnie dla jego nawigowalnych map podrzędnych i przybliżonych dopasowań.

Metody ConcurrentMap

Sr.No. Metoda i opis
1

NavigableSet<K> descendingKeySet()

Zwraca widok NavigableSet w odwrotnej kolejności kluczy zawartych w tej mapie.

2

ConcurrentNavigableMap<K,V> descendingMap()

Zwraca widok odwrotnej kolejności mapowań zawartych w tej mapie.

3

ConcurrentNavigableMap<K,V> headMap(K toKey)

Zwraca widok części tej mapy, której klucze są mniejsze niż toKey.

4

ConcurrentNavigableMap<K,V> headMap(K toKey, boolean inclusive)

Zwraca widok części tej mapy, której klucze są mniejsze niż (lub równe, jeśli wartość włącznie jest prawdą) toKey.

5

NavigableSet<K> keySet()

Zwraca widok NavigableSet kluczy zawartych w tej mapie.

6

NavigableSet<K> navigableKeySet()

Zwraca widok NavigableSet kluczy zawartych w tej mapie.

7

ConcurrentNavigableMap<K,V> subMap(K fromKey, boolean fromInclusive, K toKey, boolean toInclusive)

Zwraca widok części tej mapy, której klucze obejmują zakres od fromKey do toKey.

8

ConcurrentNavigableMap<K,V> subMap(K fromKey, K toKey)

Zwraca widok części tej mapy, której klucze obejmują zakres od odKey włącznie do toKey wyłącznie.

9

ConcurrentNavigableMap<K,V> tailMap(K fromKey)

Zwraca widok części tej mapy, której klucze są większe lub równe fromKey.

10

ConcurrentNavigableMap<K,V> tailMap(K fromKey, boolean inclusive)

Zwraca widok części tej mapy, której klucze są większe niż (lub równe, jeśli wartość włącznie jest prawdą) fromKey.

Przykład

Poniższy program TestThread przedstawia użycie ConcurrentNavigableMap.

import java.util.concurrent.ConcurrentNavigableMap;
import java.util.concurrent.ConcurrentSkipListMap;

public class TestThread {

   public static void main(final String[] arguments) {
      ConcurrentNavigableMap<String,String> map =
         new ConcurrentSkipListMap<String, String>();

      map.put("1", "One");
      map.put("2", "Two");
      map.put("3", "Three");
      map.put("5", "Five");
      map.put("6", "Six");

      System.out.println("Initial ConcurrentHashMap: "+map);
      System.out.println("HeadMap(\"2\") of ConcurrentHashMap: "+map.headMap("2"));
      System.out.println("TailMap(\"2\") of ConcurrentHashMap: "+map.tailMap("2"));
      System.out.println(
         "SubMap(\"2\", \"4\") of ConcurrentHashMap: "+map.subMap("2","4"));
   }  
}

Spowoduje to następujący wynik.

Wynik

Initial ConcurrentHashMap: {1 = One, 2 = Two, 3 = Three, 5 = Five, 6 = Six}
HeadMap("2") of ConcurrentHashMap: {1 = One}
TailMap("2") of ConcurrentHashMap: {2 = Two, 3 = Three, 5 = Five, 6 = Six}
SubMap("2", "4") of ConcurrentHashMap: {2 = Two, 3 = Three}