‘壹’ 如何对HashMap中的元素进行排序
HashMap是无序的集合,对里面的元素进行排序,需要借助其他有序的集合
传统的思路: 把每一个HashMap的键值对作为一个Entry 存入到ArrayList<Entry>里. 然后对ArrayList进行排序.
java8新思路: 利用流对集合进行处理,非常强大, 如果配合上Lambda表达式, 就是简洁且强大.
参考代码
importjava.util.HashMap;
//java8流处理
publicclassDemo1{
publicstaticvoidmain(String[]args){
HashMap<String,Integer>map=newHashMap<>();
map.put("lucy",76);
map.put("tom",92);
map.put("jack",86);
//按照Key(名字)进行排序,并打印
map.entrySet().stream().sorted((e1,e2)->e1.getKey().compareTo(e2.getKey())).forEach(System.out::println);
System.out.println("-------分割线----------");
//按照value(分数)进行排序,并打印
map.entrySet().stream().sorted((e1,e2)->e1.getValue().compareTo(e2.getValue())).forEach(System.out::println);
}
}
‘贰’ hashmap按value排序
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;如满意,请采纳
‘叁’ java hashmap按照value来排序
ArrayList<Entry<String,String>> list = new ArrayList<Entry<String,String>>(sMap.entrySet());
Collections.sort(list, new Comparator<Object>(){
public int compare(Object e1, Object e2){
int v1 = Integer.parseInt(((Entry<String,String>)e1).getValue().toString());
int v2 = Integer.parseInt(((Entry)e2).getValue().toString());
return v1-v2;
}
});
for (Entry<String, String> e: l){
System.out.println(e.getKey()+" "+e.getValue());
}