java hashmap排序的2种方式

1.按key排序
对名称进行排序,首先要得到HashMap中键的集合(keySet),并转换为数组,这样才能用Arrays.sort()进行排序

        Set set=phone.keySet();
        Object[] arr=set.toArray();
        Arrays.sort(arr);
        for(Object key:arr){
            System.out.println(key);
        }

得到已经排好序的键,
 

最后利用HashMap.get(key)得到键对应的值即可

for(Object key:arr)

{ System.out.println(key+": "+phone.get(key));

}

 

2.按value排序

对价格进行排序,首先需要得到HashMap中的包含映射关系的视图(entrySet),
如图:

将entrySet转换为List,然后重写比较器比较即可.这里可以使用List.sort(comparator),也可以使用Collections.sort(list,comparator)
转换为list

 List> list = new ArrayList>(phone.entrySet()); //转换为list
1
使用list.sort()排序

       list.sort(new Comparator>() {
          @Override
          public int compare(Map.Entry o1, Map.Entry o2) {
              return o2.getValue().compareTo(o1.getValue());
          }
      });
使用Collections.sort()排序

        Collections.sort(list, new Comparator>() {
           @Override
           public int compare(Map.Entry o1, Map.Entry o2) {
               return o2.getValue().compareTo(o1.getValue());
           }
       });

你可能感兴趣的:(java hashmap排序的2种方式)