用户hashMap年龄排序

it2024-02-22  64

1.全部代码:

public class TestHashMap { public static void main(String[] args) { HashMap<Integer,User> hashMap=new HashMap<Integer, User>(); User user=new User(); user.setAge(23); user.setName("name1"); hashMap.put(1,user); User user2=new User(); user2.setAge(24); user2.setName("name2"); hashMap.put(2,user2); User user3=new User(); user3.setAge(22); user3.setName("name3"); hashMap.put(3,user3); User user4=new User(); user4.setAge(21); user4.setName("name4"); hashMap.put(4,user4); System.out.println(hashMap); HashMap<Integer,User> sortHashMap=sortHashMap(hashMap); System.out.println("------------"); System.out.println(sortHashMap); } private static HashMap<Integer, User> sortHashMap(HashMap<Integer, User> hashMap) { //创建一个有序的hashmap数据结构,linkedHashMap,用于加入我们的hashMap值 LinkedHashMap<Integer,User> newHashMap=new LinkedHashMap<Integer, User>(); //map转set集合 Set<Map.Entry<Integer, User>> entrySet = hashMap.entrySet(); //set集合转为list集合 ArrayList<Map.Entry<Integer,User>> list=new ArrayList<Map.Entry<Integer, User>>(entrySet); //凡是对集合的排序,第一个想到的是集合中的工具类 //对list排序(利用集合的工具类) Collections.sort(list, new Comparator<Map.Entry<Integer, User>>() { public int compare(Map.Entry<Integer, User> o1, Map.Entry<Integer, User> o2) { return o2.getValue().getAge()-o1.getValue().getAge(); } }); //将排序好的List转换为LinkedHashMap for (int i = 0; i < list.size(); i++) { Map.Entry<Integer, User> entry = list.get(i); newHashMap.put(entry.getKey(),entry.getValue()); } //返回有序的hashMap return newHashMap; } } public class User { private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }

2.图解

3.解释:

印象中只有linkeHashMap是有序的排序就只有集合了,就想到的arrayList集合排序:callections,可以正排序也可以逆排序
最新回复(0)