java – 在实例化地图列表时获取’类型不匹配:无法从ArrayList>转换为List>’

参见英文答案 > Is List<Dog> a subclass of List<Animal>? Why are Java generics not implicitly polymorphic?                                    16个

List<Map<String, String>> recordMapList = new ArrayList<HashMap<String,String>>();

上面的行给出了错误:
类型不匹配:无法从ArrayList>转换列表>

但是如果在左侧使用HashMap而不是Map,问题就会消失.
有人能告诉我为什么会这样.
我需要让左侧包含Map,因为我可能正在使用相同的变量在右侧分配LinkedHashMap,如,

List<Map<String, String>> recordMapList = new ArrayList<LinkedHashMap <String,String>>();

请帮忙.

解决方法:

虽然ArrayList是List的子类,而Map是HashMap的子类,但是List< Map>不是List< HashMap>的子类.同样,您无法转换List< HashMap>到列表<地图>.如果可以的话,这意味着我们可以将一个TreeMap添加到List< Map>中,然后将其转换为List< HashMap>,从而违反了List< HashMap>的原始契约.

就个人而言,如果立即创建recordMapList实例,我会使用菱形运算符(Java 7):

List<Map<String, String>> recordMapList = new ArrayList<>();

如果它在其他地方创建,只有List可以是一个ArrayList,但其余的都是相同的. (注意:你当然可以在这里使用钻石操作符,但是如果创建实例和实际字段是分开的,我个人更喜欢使用这些类型,以便立即清楚列表中的类型,而不会跳转到代码中的实际字段.)

List<Map<String, String>> recordMapList;
...
recordMapList = new ArrayList<Map<String, String>>();

在这两种情况下,您都可以添加HashMap< String,String>实例到recordMapList.

上一篇:Java从LinkedHashMap获取值,其中包含密钥的一部分


下一篇:java – 在调用LinkedHashMap的put()方法之后,如何在’之前’和’之后’变量更新?