java对HashMap中的key或者value值进行排序!

前段时间从csdn 上看到了一个问题。 有个网友解答的很巧妙。

以下是问题原型,我对其中做了一些修改。

java 可以按照 HashMap 中的 key 或者 value 来进行排序。


[java]  view plain  copy
  1. import java.util.*;  
  2.   
  3. public class MapTest {  
  4.   
  5.     public static void main(String[] args) {  
  6.         Map<String, Integer> map = new HashMap<String, Integer>();  
  7.         map.put("d"2);  
  8.         map.put("c"1);  
  9.         map.put("b"4);  
  10.         map.put("a"3);  
  11.         List<Map.Entry<String, Integer>> infoIds = new ArrayList<Map.Entry<String, Integer>>(map.entrySet());  
  12.   
  13.         // 对HashMap中的key 进行排序  
  14.         Collections.sort(infoIds, new Comparator<Map.Entry<String, Integer>>() {  
  15.             public int compare(Map.Entry<String, Integer> o1,  
  16.                     Map.Entry<String, Integer> o2) {  
  17. //              System.out.println(o1.getKey()+"   ===  "+o2.getKey());  
  18.                 return (o1.getKey()).toString().compareTo(o2.getKey().toString());  
  19.             }  
  20.         });  
  21.         // 对HashMap中的key 进行排序后  显示排序结果  
  22.         for (int i = 0; i < infoIds.size(); i++) {  
  23.             String id = infoIds.get(i).toString();  
  24.             System.out.print(id + "  ");  
  25.         }  
  26.           
  27.         System.out.println();  
  28.           
  29.         // 对HashMap中的 value 进行排序  
  30.         Collections.sort(infoIds, new Comparator<Map.Entry<String, Integer>>() {  
  31.             public int compare(Map.Entry<String, Integer> o1,  
  32.                     Map.Entry<String, Integer> o2) {  
  33.                 return (o1.getValue()).toString().compareTo(o2.getValue().toString());  
  34.             }  
  35.         });  
  36.   
  37.         // 对HashMap中的 value 进行排序后  显示排序结果  
  38.         for (int i = 0; i < infoIds.size(); i++) {  
  39.             String id = infoIds.get(i).toString();  
  40.             System.out.print(id + "  ");  
  41.         }  
  42.   
  43.     }  
  44.   
  45. }  


以下是问题链接地址: http://topic.csdn.net/u/20110621/18/db4e6e64-da20-4933-8fa3-3b5a870d71ff.html?29502   

有个叫做 exterminator 的朋友解答的很巧妙。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值