在本教程中,我们将通过一个示例学习 Java NavigableMap
接口及其方法。
Java 集合框架的NavigableMap
接口提供了在映射条目之间导航的功能。
它被视为 SortedMap 的一种。
实现NavigableMap
的类
由于NavigableMap
是一个接口,因此我们无法从中创建对象。
为了使用NavigableMap
接口的功能,我们需要使用实现NavigableMap
的TreeMap
类。
如何使用NavigableMap
?
在 Java 中,我们必须导入java.util.NavigableMap
包才能使用NavigableMap
。 导入包后,将按照以下方法创建可导航的映射。
// NavigableMap implementation by TreeMap class
NavigableMap<Key, Value> numbers = new TreeMap<>();
在上面的代码中,我们创建了一个名为TreeMap
类的number
的可导航映射。
这里,
key
- 用于关联映射中每个元素(值)的唯一标识符value
- 映射中与按键相关联的元素
NavigableMap
的方法
NavigableMap
被认为是SortedMap
的一种。 这是因为NavigableMap
扩展了SortedMap
接口。
因此,所有SortedMap
方法在NavigableMap
中也可用。 要了解SortedMap
中如何定义这些方法,请访问 Java SortedMap 。
但是,SortedMap
(headMap()
,tailMap()
和subMap()
)中的某些方法在NavigableMap
中定义不同。
让我们看看如何在NavigableMap
中定义这些方法。
headMap(key, booleanValue)
headMap()
方法返回在指定的key
(作为参数传递)之前与所有这些键关联的可导航映射的所有条目。
booleanValue
是可选参数。 其默认值为false
。
如果将true
作为booleanValue
传递,则该方法返回与所有在指定的key
之前的所有键相关联的条目,包括与指定的key
。
tailMap(key, booleanValue)
tailMap()
方法返回与指定键key
(作为参数传递)之后的所有那些键相关联的可导航映射的所有条目,包括与指定key
相关的条目 。
booleanValue
是可选参数。 其默认值为true
。
如果false
作为booleanValue
传递,则该方法将返回指定的key
之后与这些键相关的所有条目,而不包括与指定的key
。
subMap(k1, bv1, k2, bv2)
subMap()
方法返回与k1
和k2
之间的键相关联的所有条目,包括与k1
相关联的条目。
bv1
和bv2
是可选参数。bv1
的默认值为true
,bv2
的默认值为false
。
如果false
作为bv1
传递,则该方法返回与k1
和k2
之间的键相关联的所有条目,而不包括与k1
相关联的条目。
如果true
作为bv2
传递,则该方法返回与k1
和k2
之间的键相关联的所有条目,包括与k1
相关联的条目。
其他方法
NavigableMap
提供了各种可用于定位映射条目的方法。
DescendingMap()
- 反转映射中的条目顺序DescendingKeyMap()
- 反转映射中按键的顺序ceilingEntry()
- 返回其键大于或等于指定键的所有条目中键最低的条目ceilingKey()
- 返回大于或等于指定键的那些键中的最低键floorEntry()
- 返回其键小于或等于指定键的所有条目中具有最高键的条目floorKey()
- 返回小于或等于指定键的那些键中的最高键upperEntry()
: - 返回其键大于指定键的所有条目中键最低的条目upperKey()
: - 返回大于指定键的那些键中的最低键lowerEntry()
: - 返回其键小于指定键的所有条目中具有最高键的条目lowerKey()
: - 返回小于指定键的那些键中的最高键firstEntry()
: - 返回映射的第一个条目(具有最低键的条目)lastEntry()
: - 返回映射的最后一个条目(具有最高键的条目)pollFirstEntry()
: - 返回并删除映射的第一个条目pollLastEntry()
: - 返回并删除映射的最后一个条目
要了解更多信息,请访问 Java NavigableMap
(Java 官方文档)。
TreeMap
类中NavigableMap
的实现
import java.util.NavigableMap;
import java.util.TreeMap;
class Main {
public static void main(String[] args) {
// Creating NavigableMap using TreeMap
NavigableMap<String, Integer> numbers = new TreeMap<>();
// Insert elements to map
numbers.put("Two", 2);
numbers.put("One", 1);
numbers.put("Three", 3);
System.out.println("NavigableMap: " + numbers);
// Access the first entry of the map
System.out.println("First Entry: " + numbers.firstEntry());
// Access the last entry of the map
System.out.println("Last Entry: " + numbers.lastEntry());
// Remove the first entry from the map
System.out.println("Removed First Entry: " + numbers.pollFirstEntry());
// Remove the last entry from the map
System.out.println("Removed Last Entry: " + numbers.pollLastEntry());
}
}
输出
NavigableMap: {One=1, Three=3, Two=2}
First Entry: One=1
Last Entry: Two=2
Removed First Entry: One=1
Removed Last Entry: Two=2
要了解有关TreeMap
的更多信息,请访问 Java TreeMap 。
现在我们知道了NavigableMap
接口,我们将在下一个教程中详细了解如何使用TreeMap
类实现该接口。