【口试】Map放进去重复key-value对
【面试】Map放进去重复key-value对import java.util.ArrayListimport java.util.HashMapimport java.util.
【面试】Map放进去重复key-value对
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
- // 查找ValueSystem.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=456it.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();}
- }
欢迎访问老紫竹的网站(http://www.java2000.net)和我在CSDN的博客(http://blog.csdn.net/java2000_net);
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实现