在 Java 中对 HashMap 进行排序:基于值的技术
在 Java 中,HashMap 是用于存储键值对的有价值的集合,但是它们不维护特定的排序顺序。要根据值对 HashMap 进行排序,我们需要采用额外的技术。
基于值的排序方法
一种方法是将 HashMap 转换为列表使用values() 方法获取值。然后我们可以使用定义所需排序逻辑的比较器对列表进行排序。
Map<String, Person> people = new HashMap<>(); Person jim = new Person("Jim", 25); Person scott = new Person("Scott", 28); Person anna = new Person("Anna", 23); people.put(jim.getName(), jim); people.put(scott.getName(), scott); people.put(anna.getName(), anna); List<Person> peopleByAge = new ArrayList<>(people.values()); Collections.sort(peopleByAge, Comparator.comparing(Person::getAge));
对列表进行排序后,我们可以访问排序后的元素。
另一种方法,适合频繁访问,就是创建一个HashMap到有序集合的映射。例如,我们可以使用 HashMap
考虑 TreeMap
如果首选按键排序,则值得考虑使用 TreeMap。 TreeMaps 根据键自动维护自然排序顺序。
以上是如何按 Java HashMap 的值对它进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!