类型安全性:未经检查的演员表

类型安全性:未经检查的演员表,第1张

类型安全性:未经检查的演员表

好吧,首先,你正在通过新的HashMap创建调用浪费内存。你的第二行完全忽略了对此创建的哈希图的引用,从而使该哈希图可用于垃圾收集器。因此,不要这样做,请使用:

private Map<String, String> someMap = (HashMap<String, String>)getApplicationContext().getBean("someMap");

其次,编译器抱怨你将对象强制转换为,HashMap而不检查它是否为HashMap。但是,即使你要这样做:

if(getApplicationContext().getBean("someMap") instanceof HashMap) {    private Map<String, String> someMap = (HashMap<String, String>)getApplicationContext().getBean("someMap");}

你可能仍然会收到此警告。问题是

getBean
return
Object
,所以类型是未知的。将其
HashMap
直接转换为第二种情况不会引起问题(并且在第一种情况下可能不会发出警告,我不确定Java编译器对Java 5发出警告有多学问)。但是,你正在将其转换为
HashMap<String, String>

HashMaps实际上是将对象作为键并将对象作为值的地图(

HashMap<Object, Object>
如果愿意)。因此,不能保证在获取bean时可以将其表示为a,
HashMap<String, String>
因为
HashMap<Date, Calendar>
返回的非泛型表示可以具有任何对象,因此可以将其表示为。

如果代码可以编译,并且你可以执行

String value = map.get("thisString")
;而没有任何错误,则不必担心此警告。但是,如果映射不是完全由字符串键组成的,则ClassCastException在运行时会得到一个,因为泛型无法阻止这种情况的发生。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5014367.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-11-14
下一篇2022-11-15

发表评论

登录后才能评论

评论列表(0条)

    保存