我有 2 个带有 <Integer, "sometype">
的哈希映射。所以"某种类型"可能会有所不同,因此我试图让它通用。在这种情况下,我的两个变量如下
private HashMap<Integer, UI_FieldPV> values_map = new HashMap<Integer, UI_FieldPV>();
private HashMap<Integer, JComponent> input_map = new HashMap<Integer, JComponent>();
该方法的第一次调用很好:
this.input_map = MapOperations.<JComponent> rearrengeHashMapIdx(this.input_map);
第二个调用传递一个带有<Integer, CustomClass>
的哈希映射
this.values_map = MapOperations.<UI_FieldPV>rearrengeHashMapIdx(this.input_map);
这给了我以下错误:
包含泛型方法的类类型
UI.MapOperations
的参数化方法<UI_FieldPV>rearrengeHashMapIdx(HashMap<Integer,UI_FieldPV>)
不适用于参数(HashMap<Integer,JComponent>)
的编码(顺便说一句:我试图在调用类中创建一种泛型方法,但它不起作用。我是否必须创建一个嵌入式类才能使泛型方法参数器工作?
private static class MapOperations<T> {
public static <T> HashMap<Integer, T> rearrengeHashMapIdx(HashMap<Integer, T> source) {
HashMap<Integer, T> temp = new HashMap<Integer, T>();
for (Integer i = 0; i < 81; i++) {
Integer rowNum = (i / 3) % 3;
Integer block = i / 9;
Integer delta = (rowNum - block);
Integer newIdx = i + (delta * 6);
temp.put(i, source.get(newIdx));
}
return temp;
}
}
那我做错了什么呢?提前感谢您的帮助!
编译器错误非常明显。方法的第一次调用:
this.input_map = MapOperations.<JComponent>rearrengeHashMapIdx(this.input_map);
将返回一个HashMap<Integer, JComponent>
,因为您已经给出了显式类型参数(好吧,这里并不真正需要。无论如何,T
类型将从您传递的HashMap
类型推断出来)。这很好,因为您已声明您的input_map
仅属于该类型。
然后,您将input_map
作为参数传递给下一个方法调用:
this.values_map = MapOperations.<UI_FieldPV>rearrengeHashMapIdx(this.input_map);
现在,根据方法的声明,该方法的参数应为 HashMap<Integer, T>
类型。在第二个方法调用中,类型参数 T
推断为 UI_FieldPV
。因此,该方法需要HashMap<Integer, UI_FieldPV>
,但您正在传递HashMap<Integer, JComponent>
。当然,方法调用会失败,因为两个映射都不兼容。
也许,在第二次调用中,您打算将values_map
作为参数传递。所以这将正常工作:
this.values_map = MapOperations.<UI_FieldPV>rearrengeHashMapIdx(this.values_map);
请注意,方法中使用的类型参数T
与类声明一起使用的类型参数T
无关,尽管这在这里没有任何区别。但仅供参考。
明白,你故意放"input_map"?
this.values_map = MapOperations.<UI_FieldPV>rearrengeHashMapIdx(this.input_map);
也许你需要这样的东西:
this.values_map = MapOperations.<UI_FieldPV>rearrengeHashMapIdx(this.values_map);