遍历map几种方式及应用

Map<String, String> map = new HashMap<String, String>();
  map.put("1", "value1");
  map.put("2", "value2");
  map.put("3", "value3");
 
  //第一种:广泛使用,二次取值
  System.out.println("经过Map.keySet遍历key和value:");
  for (String key : map.keySet()) {
   System.out.println("key= "+ key + " and value= " + map.get(key));
  }
 
  //第二种
  System.out.println("经过Map.entrySet使用iterator遍历key和value:");
  Iterator<Map.Entry<String, String>> it = map.entrySet().iterator();
  while (it.hasNext()) {
   Map.Entry<String, String> entry = it.next();
   System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
  }
 
  //第三种:推荐,尤为是容量大时
  System.out.println("经过Map.entrySet遍历key和value");
  for (Map.Entry<String, String> entry : map.entrySet()) {
   System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
  } 数组

  //第四种
  System.out.println("经过Map.values()遍历全部的value,但不能遍历key");
  for (String v : map.values()) {
   System.out.println("value= " + v);
  } get

public class HashMapTest1 {     /**      * 找出一个数组中一个数字出现次数最多的数字      * 用HashMap的key来存放数组中存在的数字,value存放该数字在数组中出现的次数      * @author guolz      */     public static void main(String[] args)     {         int[] array = {2, 1, 2, 3, 4, 5, 2, 2, 2, 2};                  //map的key存放数组中存在的数字,value存放该数字在数组中出现的次数         HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();                  for(int i = 0; i < array.length; i++)         {             if(map.containsKey(array[i]))             {                 int temp = map.get(array[i]);                                  map.put(array[i], temp + 1);             }             else             {                 map.put(array[i], 1);             }         }                  Collection<Integer> count = map.values();                  //找出map的value中最大的数字,也就是数组中数字出现最多的次数         int maxCount = Collections.max(count);                  int maxNumber = 0;                  for(Map.Entry<Integer, Integer> entry : map.entrySet())         {             //获得value为maxCount的key,也就是数组中出现次数最多的数字             if(maxCount == entry.getValue())             {                 maxNumber = entry.getKey();             }         }                  System.out.println("出现次数最多的数字为:" + maxNumber);         System.out.println("该数字一共出现" + maxCount + "次");     } }
相关文章
相关标签/搜索