在我的spring应用程序上下文文件中,我有如下内容:
<util:map id="someMap" map-class="java.util.HashMap" key-type="java.lang.String" value-type="java.lang.String">
<entry key="some_key" value="some value" />
<entry key="some_key_2" value="some value" />
</util:map>
在java类中,实现看起来像:
private Map<String, String> someMap = new HashMap<String, String>();
someMap = (HashMap<String, String>)getApplicationContext().getBean("someMap");
在Eclipse中,我看到一个警告说:
类型安全:未检查从Object转换到HashMap<String,String>
出了什么问题?
如上面的消息所示,List不能区分List<Object>和List<String>或List<Integer>。
我已经解决了类似问题的错误信息:
List<String> strList = (List<String>) someFunction();
String s = strList.get(0);
与以下:
List<?> strList = (List<?>) someFunction();
String s = (String) strList.get(0);
解释:第一个类型转换验证对象是一个List,而不关心其中持有的类型(因为我们不能在List级别验证内部类型)。现在需要进行第二次转换,因为编译器只知道List包含某种类型的对象。这将在访问List时验证每个对象的类型。
我做错了什么?如何解决这个问题?
在这里:
地图<字符串,字符串> someMap =(文件夹<字符串,字符串>)getApplicationContext(“someMap”);
你使用一个我们通常不希望使用的遗留方法,因为它返回Object:
Object getBean(String name) throws BeansException;
从bean工厂获取(单例)/创建(原型)bean的方法是:
<T> T getBean(String name, Class<T> requiredType) throws BeansException;
使用它,如:
Map<String,String> someMap = app.getBean(Map.class,"someMap");
将编译,但仍然带有未检查的转换警告,因为所有Map对象不一定是Map<String, String>对象。
但是<T> T getBean(字符串名称,类<T> requiredType)抛出BeansException;在bean泛型类(如泛型集合)中是不够的,因为这需要指定多个类作为参数:集合类型及其泛型类型。
在这种情况下以及一般情况下,更好的方法是不直接使用BeanFactory方法,而是让框架注入bean。
bean声明:
@Configuration
public class MyConfiguration{
@Bean
public Map<String, String> someMap() {
Map<String, String> someMap = new HashMap();
someMap.put("some_key", "some value");
someMap.put("some_key_2", "some value");
return someMap;
}
}
注豆:
@Autowired
@Qualifier("someMap")
Map<String, String> someMap;