java中获取map的key和value的方法

最近做POI反射方法实现的时候,遇到了map的取值相关的问题,在这里总结下。
获取map的key和value的方法分为两种形式:

map.keySet():先获取map的key,然后根据key获取对应的value;
map..entrySet():同时查询map的key和value,只需要查询一次;
两者的性能比较可以查看map.keySet()和map.EntrySet()的比较。

1、以下是获取map的key和value,以及map里面的元素通过key或者value来比较大小并排序;
【注意:当map的value值相等时,根据key值进行排序】

public class MapSort {
 public static void main(String[] args) {
  Map<String,String> map = new HashMap<String,String>();
  map.put("b","4");
  map.put("a","5");
  map.put("c","3");
  map.put("d","5");
  //通过map.keySet()方法
  //方法一:通过得到key的值,然后获取value;
  /*for(String key : map.keySet()){
   String value = map.get(key);
   System.out.println(key+"  "+value);
  }*/

  //使用迭代器,获取key;
  /*Iterator<String> iter = map.keySet().iterator();
  while(iter.hasNext()){
   String key=iter.next();
   String value = map.get(key);
   System.out.println(key+" "+value);
   */

  //通过map.entrySet()方法
  //方法一:循环map里面的每一对键值对,然后获取key和value
  /*for(Entry<String, String> vo : map.entrySet()){
   vo.getKey();
   vo.getValue();
   System.out.println(vo.getKey()+"  "+vo.getValue());
  }*/

  /*//使用迭代器,获取key
  Iterator<Entry<String,String>> iter = map.entrySet().iterator();
  while(iter.hasNext()){
   Entry<String,String> entry = iter.next();
   String key = entry.getKey();
   String value = entry.getValue();
   System.out.println(key+" "+value);
  }*/

  //将map<String,String> 转化为ArryList,但list里面的元素为Entry<String,String>
  List<Entry<String,String>> list = new ArrayList<Map.Entry<String,String>>(map.entrySet());
  //通过匿名比较器的方式进行比较。
  Collections.sort(list,new Comparator<Entry<String,String>>(){
   @Override
   public int compare(Entry<String, String> o1,
     Entry<String, String> o2) {
    int flag = o1.getValue().compareTo(o2.getValue());
    if(flag==0){
     return o1.getKey().compareTo(o2.getKey());
    }
    return flag;
   }
  });
  //遍历list得到map里面排序后的元素
  for(Entry<String, String> en : list){
   System.out.println(en.getKey()+" "+en.getValue());
  }
 }
}

2、注意Map中的元素是唯一无序的,如果希望根据存入的顺序取出数据,建议使用linkedhashmap,存入其中的数据是唯一且有序的。


Previous
java中类和类之间的关系 java中类和类之间的关系
java中类和类之间的关系 (如下图所示):
2018-12-04 Pursue
Next
Java中对List中的存储对象根据属性进行排序的办法 Java中对List中的存储对象根据属性进行排序的办法
有时候需要对集合中的元素按照一定的规则进行排序,对于比较简单单一的数据可以用Java中提供的对集合进行操作的工具类Collections中的sort方法,对于对象,如果要一依据属性进行排序,就需要参与比较的对象实现ComparableT接口
2018-12-04 Pursue