Map简介
映射(Map):一系列“键-值”对。从表面看,我们可以方便地查看Map的某个部分。只需创建一个集合,然后用它表示那一部分即可。这样一来,Map就可以返回自己键的一个Set、一个包含自己值的List或者包含自己“键-值”对的一个List。(简单的列出了Think in Java中的几句话)
Map的简单使用以及三种遍历方式
// 创建集合对象
Map<String, String> map = new HashMap<String, String>();
// 创建并添加元素
map.put("1", "姚明");
map.put("2", "奥胖");
map.put("3", "火花");
// 获取key的集合
Set<String> set = map.keySet();
// 遍历Set集合
Iterator<String> it = set.iterator();
while (it.hasNext()) {
String s = it.next();
System.out.println(s);
(这里就是map的key 1、2、3)
}
// 获取value的集合
Collection<String> c = map.values();
// 遍历Collection集合
it = c.iterator();
while (it.hasNext()) {
String s = it.next();
System.out.println(s);
(这里就是map的value 姚明、奥胖、火花)
}
我们使用集合存储数据就是为了读取数据接下来我们看看Map集合的遍历
// 遍历----先拿到Map集合的key然后在根据key取对应的value值
Set<String> set = map.keySet();
for (String key : set) {
String value = map.get(key);
System.out.println(key + "-----"+value);
}
// 遍历----先拿到Map集合的value值的集合然后遍历这个集合
Collection values = map.values();
Iterator iterator = values.iterator();
while (iterator.hasNext()){
System.out.println("value " +"-----"+ iterator.next());
}
// 遍历----先拿到Map集合的映射对象的集合然后在从中取出数据
// Map集合有一个Entry集合存放其key和value的对应关系
Set<Map.Entry<String, String>> set = map.entrySet();
for (Entry<String, String> entry: set) {
String key = entry.getKey();//获取map的key
String value = entry.getValue();//获取map的value
System.out.println(key + "-----" + value);
}
Map集合的子类实现与对比
|--Map(双列 底层结构是针对键有效,跟值无关,Map有三个子类分别是)
|--HashMap
底层数据结构是哈希表。
线程不安全,效率高。
允许null键和值。
|--Hashtable
底层数据结构是哈希表。
线程安全,效率低。
不允许null键和值。
|--TreeMap
底层数据结构是二叉树。
线程不安全,效率高。
什么时候使用map什么时候使用collection
是否键值对?
是:Map
是否对键排序?
是:TreeMap
否:HashMap
否:Collection
有时候为了保证map集合数据的唯一性我们必须重写equals() 和 hashCode()方法,这两个方法应该是必须掌握的。可以看一下这个写的非常好。
equals() 和 hashCode()方法的重写
thanks
https://java.quanke.name/8.7%20%E6%96%B0%E9%9B%86%E5%90%88.html
http://blog.csdn.net/u011240877/article/details/52929523