老紫竹JAVA提高教程(11)-认识Map
|
zhaoxq
老紫竹 ![]()
管理员
|
1 # 大 中 小 发表于 2008-12-03 07:57:55
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实现
快乐渡过每一天,减肥坚持每一天
|
|||||
|




