以 TreeMap<K, V> 作为参数的简单泛型方法
Simple generic method with TreeMap<K, V> as parameter
我正在尝试编写一个通用方法来迭代 TreeMap 条目以使用其键获取值(我正在使用自定义比较器根据值对地图进行排序,结果破坏了 get()方法,但这不是我要在这里解决的问题)。到目前为止我得到了以下内容,但我不明白为什么符号 'K' 和 'V' 没有被解析——即使它们是在传入的 TreeMap 上声明的。
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;
}
我承认我不是泛型方面的专家,如果这很明显,我深表歉意。
您需要在 return 类型之前声明泛型参数:
private <K, V> V forceGet(TreeMap<K, V> sortedMap, K targetKey) { ... }
我认为你必须在函数中声明 K 和 V:
private <K,V> V forceGet(...)
{
//your code
}
我正在尝试编写一个通用方法来迭代 TreeMap 条目以使用其键获取值(我正在使用自定义比较器根据值对地图进行排序,结果破坏了 get()方法,但这不是我要在这里解决的问题)。到目前为止我得到了以下内容,但我不明白为什么符号 'K' 和 'V' 没有被解析——即使它们是在传入的 TreeMap 上声明的。
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;
}
我承认我不是泛型方面的专家,如果这很明显,我深表歉意。
您需要在 return 类型之前声明泛型参数:
private <K, V> V forceGet(TreeMap<K, V> sortedMap, K targetKey) { ... }
我认为你必须在函数中声明 K 和 V:
private <K,V> V forceGet(...)
{
//your code
}