Map可以为某些数据提供快速查找功能,通过关键字(key)可以快速的得到对应的Value,而不用像List那样需要大范围的遍历或特别的算法。

1 源代码
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.Map.Entry;

/**
 * 老紫竹JAVA提高教程(11)-认识Map<br>
 * 将键映射到值的对象。<br>
 * 一个映射不能包含重复的键;每个键最多只能映射到一个值。<br>
 * <br>
 * 相关API请查看 api.java2000.net/Map
 * 
 * @author 老紫竹 JAVA世纪网(java2000.net)
 */
public class Lession {
  public static void main(String[] args) {
    // 构造一个Map
    // 我们使用HashMap进行测试
    Map map = new HashMap();

    // 查看map是否为空
    System.out.println(map.isEmpty()); // true

    // 存入数据
    // put方法会返回原来的值
    // 如果是第一次赋值,则返回null;
    System.out.println(map.put("id", "123")); // null
    map.put("name", "xyz");

    // 再次查看map是否为空
    System.out.println(map.isEmpty()); // false

    // 查看有多少数据了
    System.out.println("size=" + map.size()); // size=2

    // 查看所有的数据
    showMap(map); // id=>123; name=>xyz;

    // 获取数据
    System.out.println("name=" + map.get("name")); // name=xyz

    // 放入不同key类型的数据
    map.put(new Integer(1), new Object());
    // 放入集合类型
    Set set = new HashSet();
    set.add(111);
    set.add(222);
    List list = new ArrayList();
    list.add(333);
    list.add(444);
    map.put(set, list);
    // 甚至放入Map类型
    Map m = new HashMap();
    m.put("mm", "mmmm");
    map.put(m, "map in map");

    // id=>123; 1=>java.lang.Object@de6ced; {mm=mmmm}=>map in map; name=>xyz;
    // [222, 111]=>[333, 444];
    showMap(map);

    // 我们尝试放入重复key的数据
    System.out.println(map.put("id", "456")); // 123

    // 可以看到,原来的数据value被覆盖了
    // id=>456; 1=>java.lang.Object@de6ced; {mm=mmmm}=>map in map; name=>xyz;
    // [222, 111]=>[333, 444];
    showMap(map);

    // 检查是否存在我们需要的数据
    // 查找key值
    System.out.println(map.containsKey("name")); // true
    // 查找Value
    System.out.println(map.containsValue(list)); // true

    // 删除一些数据
    // 是根据key进行删除的
    System.out.println(map.remove(m)); // map in map
    showMap(map); // id=>456; 1=>java.lang.Object@de6ced; name=>xyz; [222,
    // 111]=>[333, 444];

    // Entry的集合
    // 内部就是Map实现的,所以对其操作是互相影响的
    // 不支持add操作,
    Set<Entry> ms = map.entrySet();

    // [id=456, 1=java.lang.Object@de6ced, name=xyz, [222, 111]=[333, 444]]
    System.out.println(ms);
    System.out.println(ms.size() + "/" + map.size()); // 4/4

    // 尝试通过entrySet删除
    Iterator<Entry> it = ms.iterator();
    if (it.hasNext()) {
      Entry e = it.next();
      System.out.println(e.getKey() + "=" + e.getValue()); // id=456
      it.remove();
    }
    System.out.println(ms.size() + "/" + map.size()); // 3/3

    // 清除所有数据
    map.clear();
    System.out.println(ms.size() + "/" + map.size()); // 0/0
  }

  public static void showMap(Map map) {
    // 迭代Key的操作
    Iterator it = map.keySet().iterator();
    Object key;
    while (it.hasNext()) {
      key = it.next();
      System.out.print(key + "=>" + map.get(key) + "; ");
    }
    System.out.println();
  }
}


2 运行结果
true
null
false
size=2
id=>123; name=>xyz;
name=xyz
id=>123; 1=>java.lang.Object@de6ced; {mm=mmmm}=>map in map; name=>xyz; [222, 111]=>[333, 444];
123
id=>456; 1=>java.lang.Object@de6ced; {mm=mmmm}=>map in map; name=>xyz; [222, 111]=>[333, 444];
true
true
map in map
id=>456; 1=>java.lang.Object@de6ced; name=>xyz; [222, 111]=>[333, 444];
[id=456, 1=java.lang.Object@de6ced, name=xyz, [222, 111]=[333, 444]]
4/4
id=456
3/3
0/0


3 测试:
  尝试放入各种对象类型,并检测和删除它们

4 总结
  map的put和get是关键,不同的实现Map的方式有一点差别,我们会在后面的介绍里讲解常用的Map实现
快乐渡过每一天,减肥坚持每一天