Java 使用TreeMap的简单通用方法<;K、 V>;作为参数
我正试图编写一个泛型方法,迭代TreeMap条目以获得一个带有键的值(我使用一个自定义比较器根据值对映射进行排序,结果破坏了get()方法,但这不是我在这里要解决的问题)。到目前为止,我已经了解了以下内容,但我不明白为什么符号“K”和“V”没有解析——即使它们是在传入的树映射上声明的Java 使用TreeMap的简单通用方法<;K、 V>;作为参数,java,generics,key-value,treemap,Java,Generics,Key Value,Treemap,我正试图编写一个泛型方法,迭代TreeMap条目以获得一个带有键的值(我使用一个自定义比较器根据值对映射进行排序,结果破坏了get()方法,但这不是我在这里要解决的问题)。到目前为止,我已经了解了以下内容,但我不明白为什么符号“K”和“V”没有解析——即使它们是在传入的树映射上声明的 private V forceGet(TreeMap<K, V> sortedMap, K targetKey) { for (Map.Entry e : sortedMap.entrySet
private V forceGet(TreeMap<K, V> sortedMap, K targetKey) {
for (Map.Entry e : sortedMap.entrySet()) {
K key = (K) e.getKey();
V value = (V) e.getValue();
if (key.equals(targetKey)) {
return value;
}
}
return null;
}
private V forceGet(树形图分类图,K targetKey){
对于(Map.Entry e:sortedMap.entrySet()){
K key=(K)e.getKey();
V value=(V)e.getValue();
if(key.equals(targetKey)){
返回值;
}
}
返回null;
}
我承认我不是泛型方面的专家,因此如果这是显而易见的,我深表歉意。您需要在返回类型之前声明泛型参数:
private <K, V> V forceGet(TreeMap<K, V> sortedMap, K targetKey) { ... }
private V forceGet(TreeMap sortedMap,K targetKey){…}
我认为您必须在函数中声明K和V:
private <K,V> V forceGet(...)
{
//your code
}
private V forceGet(…)
{
//你的代码
}
您的方法不是泛型的。这是关于还读的教程,我知道你的问题是关于泛型的,但是如果你破坏了TreeMap
,你确定迭代条目集会有效吗?是的,有效-TreeMap键和值都是完整的,但显然是get()方法使用我为值排序创建的同一个自定义比较器。而且Map.Entry
应该是Map.Entry
,这样就不需要强制转换key
和value