HashMap的排序

public class SortByValueDemo {

public static void main(String[] args) {

HashMap<String, Integer> datas = new HashMap<String, Integer>(){{
put("Winter Lau", 100);
put("Yier", 150);
put("Nothing", 30);
put("Zolo", 330);
}};

ByValueComparator bvc = new ByValueComparator(datas);

//第一种方法
TreeMap<String, Integer> sorted_map = new TreeMap<String, Integer>(bvc);
sorted_map.putAll(datas);

for(String name : sorted_map.keySet()){
System.out.printf("%s -> %d\n", name, datas.get(name));
}

//第二种方法
List<String> keys = new ArrayList<String>(datas.keySet());
Collections.sort(keys, bvc);
HashMap<String, Integer> tempHashMap = new HashMap<String, Integer>();
for(String key : keys) {
tempHashMap.put(key, datas.get(key));
}
System.out.println(tempHashMap);
}

static class ByValueComparator implements Comparator<String> {
HashMap<String, Integer> base_map;

public ByValueComparator(HashMap<String, Integer> base_map) {
this.base_map = base_map;
}

public int compare(String arg0, String arg1) {
if (!base_map.containsKey(arg0) || !base_map.containsKey(arg1)) {
return 0;
}

if (base_map.get(arg0) < base_map.get(arg1)) {
return 1;
} else if (base_map.get(arg0) == base_map.get(arg1)) {
return 0;
} else {
return -1;
}
}
}

}
建议使用第二种方法,第一种方法中,如果值相同,会损失键值对
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值