不知何故,我的旧问题已关闭,因此我打开了一个新问题:
我正在使用Java泛型从SQL查询中实现泛型双向Hash Map。它应该能够来回映射String,Integer对的任何组合。应该这样使用:
String sql = "SELECT string_val, int_val FROM map_table";
PickMap<String, Integer> pm1 = new PickMap<String, Integer>(sql);
String key1 = "seven";
Integer value1 = pm1.getLeft2Right(key1);
Integer key2 = 7;
String value2 = pm1.getRightToLeft(key2);
当然应该可以创建一个pm(Integer,Integer)等等。
我选择地图的实现如下所示(没有getter …):
public class PickMap<L, R> {
private final HashMap<L, R> left2Right = new HashMap<L, R>();
private final HashMap<R, L> right2Left = new HashMap<R, L>();
public PickMap(String sql) throws OException {
DTable d = new DTable(sql);
int colTypeL = d.t.getColType(1);
int colTypeR = d.t.getColType(2);
Extractor<L> extLeft = (Extractor<L>) getInstance(colTypeL);
Extractor<R> extRight = (Extractor<R>) getInstance(colTypeR);
int numRows = d.t.getNumRows();
for(int i=1;i<=numRows;i++) {
L leftVal = extLeft.extract(d, i);
R rightVal = extRight.extract(d, i);
this.left2Right.put(leftVal, rightVal);
this.right2Left.put(rightVal, leftVal);
}
}
private Extractor<?> getInstance(int type) {
if(type == 1)
return new IntExtractor();
else
return new StringExtractor();
}
}
interface Extractor<E> {
E extract(DTable source, int row);
}
class IntExtractor implements Extractor<Integer> {
@Override
public Integer extract(DTable source, int row) {
int value = 5;
return new Integer(value);
}
}
class StringExtractor implements Extractor<String> {
@Override
public String extract(DTable source, int row) {
String retVal = "hello";
return retVal;
}
}
我没有编译器错误,而且我很确定,它将以这种方式工作。但是我在“
getInstance”方法上收到未经检查的强制转换警告,在这里我将Extractor(E)转换为Extractor(L)…
我应该如何正确投放?还是我想念什么?还是我应该只禁止那些警告?
您收到警告是因为您所做的事情不能被证明是安全的。你 假设
这getInstance(colTypeL)
将返回Extractor<L>
-但不能在编译时或执行时间验证。
您可以使用@SuppressWarnings("unchecked")
其他人提到的方式,但是我会尝试重新考虑设计。
我在这里遇到了一个关于带列表的泛型有界类型的小问题。请帮帮我! 有什么方法可以克服这个问题,或者我可以安全地压制警告吗?
问题内容: Android代码-SharedPreferences类导出用于持久/检索不同首选项的不同方法: 这行得通,我可以打电话给`boolean stored = retrieve(ctx, “BOOLEAN_KEY”, true) instanceof T warning unchecked`? 编辑 :如果我要通过类,我可能会调用或等。我想要的是简化方法的内部结构,摆脱警告,但仍然可以调
问题内容: 我正在尝试制作一个称为myHash的Point HashSet的浅表副本。截至目前,我有以下内容: 这段代码给了我一个未经检查的强制转换警告。有一个更好的方法吗? 问题答案: 您可以尝试以下方法:
问题内容: 我不明白为什么在尝试执行以下操作时会收到警告(未经检查的演员表): 我的意思是将castedMap发布到外部代码的危险是什么?两种操作均可在运行时完美运行: 使用SomeType类型的键从castedMap获取元素 使用SomeType类型的键将元素放入castedMap中。 我只是使用@SuppressWarnings(“ unchecked”)取消警告。 问题答案: 答案可能很无聊
问题内容: 在我的spring应用程序上下文文件中,我有类似以下内容: 在java类中,实现如下所示: 在Eclipse中,我看到一条警告: 类型安全性:未经检查的从Object到HashMap的转换 我做错了什么?我该如何解决该问题? 问题答案: 好吧,首先,你正在通过新的HashMap创建调用浪费内存。你的第二行完全忽略了对此创建的哈希图的引用,从而使该哈希图可用于垃圾收集器。因此,不要这样做
问题内容: 请帮忙,我在以下代码中收到以下消息: PuntoNota.java AdapterDatos: 该应用程序运行良好,但是我收到以下消息: 未经检查的强制转换:从’java.io.Serializable’到’java.util.ArrayList’更少…(Ctrl + F1)。 关于此代码:(ArrayList)getIntent()。getSerializableExtra(“ my