对Map的key和value进行排序

1.1.  对集合中的key进行排序

1.1.1.   实例:对字符串形式的key进行自然逆序排序

SortMapKey.java

[java]  view plain copy
  1. package map;  
  2.   
  3.    
  4.   
  5. import java.util.Comparator;  
  6.   
  7. import java.util.LinkedHashMap;  
  8.   
  9. import java.util.Map;  
  10.   
  11. import java.util.Set;  
  12.   
  13. import java.util.TreeMap;  
  14.   
  15.    
  16.   
  17. public class SortMapKey {  
  18.   
  19.    
  20.   
  21.     public static void main(String[] args) {  
  22.   
  23.    
  24.   
  25.        Map<String,String> map = new TreeMap<String,String>(new Comparator<String>() {  
  26.   
  27.    
  28.   
  29.            public int compare(String key1, String key2) {  
  30.   
  31.                 
  32.   
  33.               return key2.compareTo(key1);  
  34.   
  35.                 
  36.   
  37.               }  
  38.   
  39.        });  
  40.   
  41.          
  42.   
  43.    
  44.   
  45.    
  46.   
  47.        //map.put(null, null);  
  48.   
  49.        map.put("aa"null);  
  50.   
  51.        map.put("bb""123");  
  52.   
  53.        map.put("dd""456");  
  54.   
  55.        map.put("cc""789");  
  56.   
  57.    
  58.   
  59.        Set<String> keySet = map.keySet();  
  60.   
  61.    
  62.   
  63.        for (String key : keySet) {  
  64.   
  65.            System.out.println(key + ":" + map.get(key));  
  66.   
  67.        }  
  68.   
  69.    
  70.   
  71.     }  
  72.   
  73.    
  74.   
  75. }  
  76.   
  77.    


 

输出结果:

dd:456

cc:789

bb:123

aa:null

1.2.  对Map中的value进行排序

1.2.1.   实例:Map中日期格式的值排序

SortMapValue.java

[java]  view plain copy
  1. package map;  
  2.   
  3.    
  4.   
  5. import java.text.SimpleDateFormat;  
  6.   
  7. import java.util.Calendar;  
  8.   
  9. import java.util.Comparator;  
  10.   
  11. import java.util.Date;  
  12.   
  13. import java.util.HashMap;  
  14.   
  15. import java.util.Map;  
  16.   
  17. import java.util.Set;  
  18.   
  19. import java.util.TreeMap;  
  20.   
  21.    
  22.   
  23. publicclass SorMaptValue {  
  24.   
  25.    
  26.   
  27.     publicstaticvoid main(String[] args) {  
  28.   
  29.          
  30.   
  31.        Map<String,Date> hashMap = new HashMap<String, Date>();  
  32.   
  33.          
  34.   
  35.        Calendar calendar = Calendar.getInstance();  
  36.   
  37.          
  38.   
  39.        calendar.add(Calendar.DATE, -1);  
  40.   
  41.        hashMap.put("昨天", calendar.getTime());  
  42.   
  43.          
  44.   
  45.        calendar.add(Calendar.DATE, 1);  
  46.   
  47.        hashMap.put("今天", calendar.getTime());  
  48.   
  49.          
  50.   
  51.    
  52.   
  53.        calendar.add(Calendar.DATE, 1);  
  54.   
  55.        hashMap.put("明天", calendar.getTime());  
  56.   
  57.          
  58.   
  59.        SortValueComparator svc = new SortValueComparator(hashMap);  
  60.   
  61.          
  62.   
  63.        Map<String,Date> map = new TreeMap<String, Date>(svc);  
  64.   
  65.        map.putAll(hashMap);  
  66.   
  67.          
  68.   
  69.    
  70.          
  71.   
  72.        Set<String> keySet = map.keySet();  
  73.   
  74.          
  75.   
  76.        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");  
  77.   
  78.          
  79.   
  80.        for (String key : keySet) {  
  81.   
  82.            System.out.println(key + ":" + sdf.format(hashMap.get(key)));  
  83.   
  84.        }  
  85.   
  86.    
  87.   
  88.     }  
  89.   
  90.    
  91.   
  92. }  
  93.   
  94.    
  95.   
  96. class SortValueComparator implements Comparator<String>{  
  97.   
  98.       
  99.   
  100.     private Map<String,Date> map ;  
  101.   
  102.       
  103.   
  104.     public SortValueComparator(Map<String,Date> map) {  
  105.   
  106.          
  107.   
  108.        this.map = map;  
  109.   
  110.          
  111.   
  112.     }  
  113.   
  114.    
  115.   
  116.     publicint compare(String o1, String o2) {  
  117.   
  118.          
  119.   
  120.        boolean flag = map.get(o1).before(map.get(o2));  
  121.   
  122.          
  123.   
  124.        if(flag){  
  125.   
  126.            return 1;  
  127.   
  128.        }else{  
  129.   
  130.              
  131.   
  132.            return -1;  
  133.   
  134.        }  
  135.   
  136.     }  
  137.   
  138.       
  139.   
  140. }  
  141.   
  142.    


 

运行结果如下:

明天:2015-02-01

今天:2015-01-31

昨天:2015-01-30

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值