Интерфейс ConcurrentNavigableMap

Интерфейс java.util.concurrent.ConcurrentNavigableMap является подинтерфейсом интерфейса ConcurrentMap и поддерживает операции NavigableMap, а также рекурсивно для его под-карт с возможностью навигации и приблизительных совпадений.

Методы ConcurrentMap

Sr.No. Метод и описание
1

NavigableSet<K> descendingKeySet()

Возвращает в обратном порядке представление NavigableSet для ключей, содержащихся на этой карте.

2

ConcurrentNavigableMap<K,V> descendingMap()

Возвращает отображение отображений, содержащихся на этой карте, в обратном порядке.

3

ConcurrentNavigableMap<K,V> headMap(K toKey)

Возвращает представление части этой карты, ключи которой строго меньше, чем toKey.

4

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

Возвращает представление части этой карты, ключи которой меньше (или равны, если включено, истинно) toKey.

5

NavigableSet<K> keySet()

Возвращает представление NavigableSet ключей, содержащихся на этой карте.

6

NavigableSet<K> navigableKeySet()

Возвращает представление NavigableSet ключей, содержащихся на этой карте.

7

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

Возвращает представление части этой карты, ключи которой находятся в диапазоне от fromKey до toKey.

8

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

Возвращает представление части этой карты, ключи которой находятся в диапазоне от fromKey включительно до toKey, исключая.

9

ConcurrentNavigableMap<K,V> tailMap(K fromKey)

Возвращает представление части этой карты, ключи которой больше или равны fromKey.

10

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

Возвращает представление части этой карты, ключи которой больше (или равны, если включено, истинно) fromKey.

пример

Следующая программа TestThread показывает использование 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"));
   }  
}

Это даст следующий результат.

Вывод

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}