// sort your map based on key, otherwise you will get IndexOutofBoundException
Map<String, String> treeMap = new TreeMap<String, String>(map)
List<String> list = new List<String>();
for (treeMap.Entry<Integer, String> entry : treeMap.entrySet()) {
list.add(entry.getKey(), entry.getValue());
}
8条答案
按热度按时间lsmd5eda1#
0dxa2lsx2#
假设您有:
对于值列表:
有关密钥列表:
注意,键和值的顺序对于HashMap是不可靠的;如果需要在键和值的列表中保持一一对应的位置,请使用LinkedHashMap。
relj7zay3#
基本上你不应该把问题和答案搞混,因为它很混乱。
然后您可以指定转换的含义并选择其中一个解决方案
zkure5ic4#
采集界面有3个视图
其他人已经回答将哈希Map转换为键和值的两个列表。它完全正确
**我的补充:**如何将“键-值对”(又名entrySet)转换为列表。
ArrayList有这个构造函数。
jk9hmnmh5#
使用Java 8和Stream API的解决方案:
用法:
carvr3hs6#
如果你只想让它遍历你的HashMap,就不需要列表:
当然,如果你想在迭代的时候从结构上修改Map(也就是说,不仅仅是改变一个已有键的值),那么你最好使用“copy to ArrayList”方法,否则你会得到ConcurrentModificationException异常,或者导出为一个数组:
kr98yfug7#
如果你想在你的列表中保持同样的顺序,说:你的Map看起来像:
你希望你的清单看起来像
您必须遍历Map:
0qx6xfy68#
我通常使用
map.values()
来获取值,然后将它们转换为列表假设您有以下散列表:
您可以从Map中获取值,然后在一行代码中将它们转换为列表,如下所示: