Map集合深入

下面一段代码是使用entrySet来将Map集合中的对象进行迭代,entrySet返回的是key与value对应的关系,它需要借助内部类Entry内的方法来获得key与value。

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
public class JiHeDemo {
    public static void main(String[] args) {
        Map m = new HashMap();
        Object value0 = m.put("lishaui", "anhui");
        m.put("wangchunxuan", "yanbian");
        m.put("wanghongliang", "changchun");
        Object value = m.put("lishaui", "beijing");
        Set s = m.entrySet();
        for (Iterator iterator = s.iterator(); iterator.hasNext();) {
            Object obj = s;
            Entry entry = (Entry) obj;
            Object value1 = entry.getValue();
            Object key = entry.getKey();
            System.out.println(key + "---" + value1);
        }
    }
}

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

//需求:求出一段字符串中字符出现的次数。
public class JiHeDemo {
    public static void main(String[] args) {
        String str = "lishuaishishijieshangzuishshuaideren";
        // 创建一个Map集合
        Map map = new HashMap();
        // 取出字符串中的字符
        for (int i = 0; i < str.length(); i++) {
            char ch = str.charAt(i);
            Object value = map.get(ch);
            if (value == null) {
                // 说明ch对应的字符不存在
                map.put(ch, 1);
            } else {
                // 将value强转为Interget类型
                Integer v = (Integer) value;
                map.put(ch, v + 1);
            }
        }
        // 遍历map集合
        Set s = map.keySet();
        for (Iterator iterator = s.iterator(); iterator.hasNext();) {
            Object key = iterator.next();
            Object value = map.get(key);
            System.out.println(key + "---" + value);
        }
    }
}

你可能感兴趣的:(Map集合深入)