Map四种获取key和value值的方法,以及对map中的元素排序

时间:2021-09-03 19:16:29

见;http://blog.csdn.net/fishroad/article/details/47421457




获取map的值主要有四种方法,这四种方法又分为两类,一类是调用map.keySet()方法来获取key和value的值,另一类则是通过map.entrySet()方法来取值,两者的区别在于,前者主要是先获取到所有的key的集合,当你需要查询value的值的时候需要通过key来查询value,后者则直接将key和value的键值对直接取出来,只用查询一次,对于那种性能更好,我觉得还是用map.entrySet()更好一点,具体请参见map.keySet()和map.EntrySet()的比较,接下来就具体介绍一下四种遍历方法以及map里面的元素通过key或者value来比较大小并排序:

[java]  view plain  copy
  1. package com.sort;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.Collections;  
  5. import java.util.Comparator;  
  6. import java.util.HashMap;  
  7. import java.util.List;  
  8. import java.util.Map;  
  9. import java.util.Map.Entry;  
  10.   
  11. public class Test {  
  12.   
  13.     public static void main(String[] args) {  
  14.         Map<String,String> map = new HashMap<String,String>();  
  15.         map.put("b","4");  
  16.         map.put("a","5");  
  17.         map.put("c","3");  
  18.         map.put("d","5");  
  19.           
  20.         //通过map.keySet()方法  
  21.         //方法一:通过得到key的值,然后获取value;  
  22.         /*for(String key : map.keySet()){ 
  23.             String value = map.get(key); 
  24.             System.out.println(key+"  "+value); 
  25.         }*/  
  26.         //使用迭代器,获取key;  
  27.         /*Iterator<String> iter = map.keySet().iterator(); 
  28.         while(iter.hasNext()){ 
  29.             String key=iter.next(); 
  30.             String value = map.get(key); 
  31.             System.out.println(key+" "+value); 
  32.         }*/  
  33.         //通过map.entrySet()方法  
  34.         //方法一:循环map里面的每一对键值对,然后获取key和value  
  35.         /*for(Entry<String, String> vo : map.entrySet()){ 
  36.             vo.getKey(); 
  37.             vo.getValue(); 
  38.             System.out.println(vo.getKey()+"  "+vo.getValue()); 
  39.         }*/  
  40.           
  41.         /*//使用迭代器,获取key 
  42.         Iterator<Entry<String,String>> iter = map.entrySet().iterator(); 
  43.         while(iter.hasNext()){ 
  44.             Entry<String,String> entry = iter.next(); 
  45.             String key = entry.getKey(); 
  46.             String value = entry.getValue(); 
  47.             System.out.println(key+" "+value); 
  48.         }*/  
  49.           
  50.         //将map<String,String> 转化为ArryList,但list里面的元素为Entry<String,String>  
  51.         List<Entry<String,String>> list = new ArrayList<Map.Entry<String,String>>(map.entrySet());  
  52.         Collections.sort(list,new Comparator<Entry<String,String>>(){  
  53.             @Override  
  54.             public int compare(Entry<String, String> o1,  
  55.                     Entry<String, String> o2) {  
  56.                 int flag = o1.getValue().compareTo(o2.getValue());  
  57.                 if(flag==0){  
  58.                     return o1.getKey().compareTo(o2.getKey());  
  59.                 }  
  60.                 return flag;  
  61.             }  
  62.         });  
  63.         //遍历list得到map里面排序后的元素  
  64.         for(Entry<String, String> en : list){  
  65.             System.out.println(en.getKey()+" "+en.getValue());  
  66.         }  
  67.           
  68.     }  
  69.   
  70. }  
  71.