[英]HashMap is already sorted by key?
我认为HashMap是无序的,当迭代键时,你不知道命令是什么? 在此示例中,看起来地图已按键编号排序:
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class Test {
public static void main(String[] args) {
String[] words = {"Car", "Cat" ,"Hello", "World", "Hi", "Bye", "Dog", "Be"};
Map<Integer, ArrayList<String>> map = new HashMap<Integer, ArrayList<String>>();
for (String word: words) {
Integer len = word.length();
List<String> l = map.get(len);
if (l == null) {
l = new ArrayList<String>();
l.add(word);
map.put(len, (ArrayList<String>) l);
}
else {
if (! l.contains(word))
l.add(word);
}
}
System.out.println(map);
}
}
输出:
{2=[Hi, Be], 3=[Car, Cat, Bye, Dog], 5=[Hello, World]}
对于小的hashCodes,HashMap变成一个数组(因为这是在下面使用的)没有要求它这样做,但它恰好是最简单的实现。
简而言之,如果向HashSet或HashMap添加0到10,您将按顺序获取它们,因为容量足够大,可以按顺序布局这些值。
Treemap是一个有序的映射,其中包含按排序顺序排列的键,而HashMap无法保证您排序的map.So,总是在需要排序键时选择Treemap
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.