Java 使用TreeMap的简单通用方法<;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

我正试图编写一个泛型方法,迭代TreeMap条目以获得一个带有键的值(我使用一个自定义比较器根据值对映射进行排序,结果破坏了get()方法,但这不是我在这里要解决的问题)。到目前为止,我已经了解了以下内容,但我不明白为什么符号“K”和“V”没有解析——即使它们是在传入的树映射上声明的

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