首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

【口试】Map放进去重复key-value对

2012-11-03 
【面试】Map放进去重复key-value对import java.util.ArrayListimport java.util.HashMapimport java.util.

【面试】Map放进去重复key-value对

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

  12. // 查看map是否为空
  13. System.out.println(map.isEmpty()); // true
  14. // 存入数据// put方法会返回原来的值
  15. // 如果是第一次赋值,则返回null;System.out.println(map.put("id", "123")); // null
  16. map.put("name", "xyz");
  17. // 再次查看map是否为空System.out.println(map.isEmpty()); // false

  18. // 查看有多少数据了
  19. System.out.println("size=" + map.size()); // size=2
  20. // 查看所有的数据showMap(map); // id=>123; name=>xyz;

  21. // 获取数据
  22. System.out.println("name=" + map.get("name")); // name=xyz
  23. // 放入不同key类型的数据map.put(new Integer(1), new Object());
  24. // 放入集合类型Set set = new HashSet();
  25. set.add(111);set.add(222);
  26. List list = new ArrayList();list.add(333);
  27. list.add(444);map.put(set, list);
  28. // 甚至放入Map类型Map m = new HashMap();
  29. m.put("mm", "mmmm");map.put(m, "map in map");

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

  32. // 我们尝试放入重复key的数据
  33. System.out.println(map.put("id", "456")); // 123
  34. // 可以看到,原来的数据value被覆盖了// id=>456; 1=>java.lang.Object@de6ced; {mm=mmmm}=>map in map; name=>xyz;
  35. // [222, 111]=>[333, 444];showMap(map);

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

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

  42. // Entry的集合
  43. // 内部就是Map实现的,所以对其操作是互相影响的// 不支持add操作,
  44. Set<Entry> ms = map.entrySet();
  45. // [id=456, 1=java.lang.Object@de6ced, name=xyz, [222, 111]=[333, 444]]System.out.println(ms);
  46. System.out.println(ms.size() + "/" + map.size()); // 4/4
  47. // 尝试通过entrySet删除Iterator<Entry> it = ms.iterator();
  48. if (it.hasNext()) {Entry e = it.next();
  49. System.out.println(e.getKey() + "=" + e.getValue()); // id=456it.remove();
  50. }System.out.println(ms.size() + "/" + map.size()); // 3/3

  51. // 清除所有数据
  52. map.clear();System.out.println(ms.size() + "/" + map.size()); // 0/0
  53. }
  54. public static void showMap(Map map) {// 迭代Key的操作
  55. Iterator it = map.keySet().iterator();Object key;
  56. while (it.hasNext()) {key = it.next();
  57. System.out.print(key + "=>" + map.get(key) + "; ");}
  58. System.out.println();}
  59. }



欢迎访问老紫竹的网站(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实现

热点排行