zoukankan      html  css  js  c++  java
  • map 常用方法

    map遍历:

    Map map = new HashMap();   
    Iterator it = map.entrySet().iterator();   
    while(it.hasNext()) {   
    Map.Entry entry = (Map.Entry) it.next();   
    Object key = entry.getKey();   
    Object value = entry.getValue();   
    }
    注意:for-each循环在java 5中被引入所以该方法只能应用于java 5或更高的版本中。
    如果你遍历的是一个空的map对象,for-each循环将抛出NullPointerException,因此在遍历前你总是应该检查空引用。

        Map<Integer, Integer> map = new HashMap<Integer, Integer>();
        for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
        System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
    }
    下面的方法比entrySet遍历在性能上稍好(快了10%),而且代码更加干净。
    Map<Integer, Integer> map = new HashMap<Integer, Integer>();
     
    //遍历map中的键
    for (Integer key : map.keySet()) {
        System.out.println("Key = " + key);
    }
    //遍历map中的值
    for (Integer value : map.values()) {
        System.out.println("Value = " + value);
    }
    方法三使用Iterator遍历
    用泛型:
    
    
    Map<Integer, Integer> map = new HashMap<Integer, Integer>();
    Iterator<Map.Entry<Integer, Integer>> entries = map.entrySet().iterator();
    while (entries.hasNext()) {
        Map.Entry<Integer, Integer> entry = entries.next();
        System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
    }
    不要泛型:
    Map map = new HashMap();
    Iterator entries = map.entrySet().iterator();
    while (entries.hasNext()) {
        Map.Entry entry = (Map.Entry) entries.next();
        Integer key = (Integer)entry.getKey();
        Integer value = (Integer)entry.getValue();
        System.out.println("Key = " + key + ", Value = " + value);
    }
    该种方式看起来冗余却有其优点所在。首先,在老版本 java中这是惟一遍历map的方式。另一个好处是,你可以在遍历时调用iterator.remove()来删除entries,另两个方法则不能。根 据javadoc的说明,如果在for-each遍历中尝试使用此方法,结果是不可预测的。


    JDK1.5中,应用新特性For
    -Each循环 Map m = new HashMap(); for(Object o : map.keySet()){ map.get(o); }
  • 相关阅读:
    计算机考研复试真题 数字求和
    计算机考研复试真题 简单计算器
    计算机考研复试真题 N阶楼梯上楼问题
    P1082 [NOIP2012 提高组] 同余方程
    进制转换
    浮点数加法
    N的阶乘
    1055 The World's Richest (25 分)
    1028 List Sorting (25 分)
    1062 Talent and Virtue (25 分)
  • 原文地址:https://www.cnblogs.com/baijin05/p/5051043.html
Copyright © 2011-2022 走看看