Я погоджуюсь з LinkedHashMap. Просто розміщуючи свої висновки та досвід, коли я стикався з проблемою, коли намагався сортувати HashMap за ключами.
Мій код для створення HashMap:
HashMap<Integer, String> map;
@Before
public void initData() {
map = new HashMap<>();
map.put(55, "John");
map.put(22, "Apple");
map.put(66, "Earl");
map.put(77, "Pearl");
map.put(12, "George");
map.put(6, "Rocky");
}
У мене є функція showMap, яка друкує записи карти:
public void showMap (Map<Integer, String> map1) {
for (Map.Entry<Integer, String> entry: map1.entrySet()) {
System.out.println("[Key: "+entry.getKey()+ " , "+"Value: "+entry.getValue() +"] ");
}
}
Тепер, коли я друкую карту перед сортуванням, вона друкується в такій послідовності:
Map before sorting :
[Key: 66 , Value: Earl]
[Key: 22 , Value: Apple]
[Key: 6 , Value: Rocky]
[Key: 55 , Value: John]
[Key: 12 , Value: George]
[Key: 77 , Value: Pearl]
Що в основному відрізняється від порядку, в якому були розміщені ключі карти.
Тепер, коли я сортую це за допомогою клавіш карти:
List<Map.Entry<Integer, String>> entries = new ArrayList<>(map.entrySet());
Collections.sort(entries, new Comparator<Entry<Integer, String>>() {
@Override
public int compare(Entry<Integer, String> o1, Entry<Integer, String> o2) {
return o1.getKey().compareTo(o2.getKey());
}
});
HashMap<Integer, String> sortedMap = new LinkedHashMap<>();
for (Map.Entry<Integer, String> entry : entries) {
System.out.println("Putting key:"+entry.getKey());
sortedMap.put(entry.getKey(), entry.getValue());
}
System.out.println("Map after sorting:");
showMap(sortedMap);
викладене:
Sorting by keys :
Putting key:6
Putting key:12
Putting key:22
Putting key:55
Putting key:66
Putting key:77
Map after sorting:
[Key: 66 , Value: Earl]
[Key: 6 , Value: Rocky]
[Key: 22 , Value: Apple]
[Key: 55 , Value: John]
[Key: 12 , Value: George]
[Key: 77 , Value: Pearl]
Ви можете бачити різницю в порядку клавіш. Відсортований порядок ключів чудовий, але порядок ключів скопійованої карти знову в тому ж порядку, що і попередня карта. Я не знаю, чи правильно це казати, але для двох хеш-карт з однаковими ключами порядок ключів однаковий. Це означає твердження, що порядок ключів не гарантується, але може бути однаковим для двох карт з однаковими ключами через невід'ємну природу алгоритму вставки ключів, якщо реалізація HashMap цієї версії JVM.
Тепер, коли я використовую LinkedHashMap для копіювання відсортованих записів у HashMap, я отримую бажаний результат (що було природно, але справа не в цьому. Суть стосується порядку ключів HashMap)
HashMap<Integer, String> sortedMap = new LinkedHashMap<>();
for (Map.Entry<Integer, String> entry : entries) {
System.out.println("Putting key:"+entry.getKey());
sortedMap.put(entry.getKey(), entry.getValue());
}
System.out.println("Map after sorting:");
showMap(sortedMap);
Вихід:
Sorting by keys :
Putting key:6
Putting key:12
Putting key:22
Putting key:55
Putting key:66
Putting key:77
Map after sorting:
[Key: 6 , Value: Rocky]
[Key: 12 , Value: George]
[Key: 22 , Value: Apple]
[Key: 55 , Value: John]
[Key: 66 , Value: Earl]
[Key: 77 , Value: Pearl]