Map 提供了一个更通用的元素存储方法。Map 集合类用于存储元素对(称作“键”和“值”),其中每个键映射到一个值。
介绍
类型介绍
Java 自带了各种 Map 类。这些 Map 类可归为三种类型:
- 通用Map,用于在应用程序中管理映射,通常在 java.util 程序包中实现
HashMap、Hashtable、Properties、LinkedHashMap、IdentityHashMap、TreeMap、WeakHashMap、ConcurrentHashMap
- 专用Map,通常我们不必亲自创建此类Map,而是通过某些其他类对其进行访问
java.util.jar.Attributes、javax.print.attribute.standard.PrinterStateReasons、java.security.Provider、java.awt.RenderingHints、javax.swing.UIDefaults
- 一个用于帮助我们实现自己的Map类的抽象类
AbstractMap
类型区别
HashMap
最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度。HashMap最多只允许一条记录的键为Null(多条会覆盖);允许多条记录的值为 Null。非同步的。
TreeMap
能够把它保存的记录根据键(key)排序,默认是按升序排序,也可以指定排序的比较器,当用Iterator 遍历TreeMap时,得到的记录是排过序的。TreeMap不允许key的值为null。非同步的。
Hashtable
与 HashMap类似,不同的是:key和value的值均不允许为null;它支持线程的同步,即任一时刻只有一个线程能写Hashtable,因此也导致了Hashtale在写入时会比较慢。
LinkedHashMap
保存了记录的插入顺序,在用Iterator遍历LinkedHashMap时,先得到的记录肯定是先插入的.在遍历的时候会比HashMap慢。key和value均允许为空,非同步的。 
基本使用
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 
 | 
 Map<String, String> map = new HashMap<String, String>();
 
 
 map.put("key1", "value1");
 
 
 map.get("key1")
 
 
 map.remove("key1");
 
 
 map.clear();
 
 
 | 
| api | 说明 | 
| clear() | 从 Map 中删除所有映射 | 
| remove(Object key) | 从 Map 中删除键和关联的值 | 
| put(Object key, Object value) | 将指定值与指定键相关联 | 
| putAll(Map t) | 将指定 Map 中的所有映射复制到此 map | 
| entrySet() | 返回 Map 中所包含映射的 Set 视图。Set 中的每个元素都是一个 Map.Entry 对象,可以使用 getKey() 和 getValue() 方法(还有一个 setValue() 方法)访问后者的键元素和值元素 | 
| keySet() | 返回 Map 中所包含键的 Set 视图。删除 Set 中的元素还将删除 Map 中相应的映射(键和值) | 
| values() | 返回 map 中所包含值的 Collection 视图。删除 Collection 中的元素还将删除 Map 中相应的映射(键和值) | 
| get(Object key) | 返回与指定键关联的值 | 
| containsKey(Object key) | 如果 Map 包含指定键的映射,则返回 true | 
| containsValue(Object value) | 如果此 Map 将一个或多个键映射到指定值,则返回 true | 
| isEmpty() | 如果 Map 不包含键-值映射,则返回 true | 
| size() | 返回 Map 中的键-值映射的数目 | 
循环遍历
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 
 | Map<String, String> map = new HashMap<String, String>();
 map.put("key1", "value1");
 map.put("key2", "value2");
 
 
 
 for (String key : map.keySet()) {
 System.out.println(key + " :" + map.get(key));
 }
 
 for (Map.Entry<String, String> entry : map.entrySet()) {
 System.out.println(entry.getKey() + " :" + entry.getValue());
 }
 
 
 
 Iterator<String> iterator = map.keySet().iterator();
 while (iterator.hasNext()) {
 String key = iterator.next();
 System.out.println(key + " :" + map.get(key));
 }
 
 
 Iterator<Map.Entry<String, String>> iterator = map.entrySet().iterator();
 while (iterator.hasNext()) {
 Map.Entry<String, String> entry = iterator.next();
 System.out.println(entry.getKey() + " :" + entry.getValue());
 }
 
 | 
HashMap四种遍历性能比较
总结
增强for循环使用方便,但性能较差,不适合处理超大量级的数据。
迭代器的遍历速度要比增强for循环快很多,是增强for循环的2倍左右。
使用entrySet遍历的速度要比keySet快很多,是keySet的1.5倍左右。
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 
 | import java.util.HashMap;import java.util.Iterator;
 import java.util.Map;
 import java.util.Map.Entry;
 
 public class TestMap {
 
 public static void main(String[] args) {
 
 Map<Integer, Integer> map = new HashMap<Integer, Integer>();
 for (int i = 0; i < 100000; i++)
 map.put(i, i);
 
 
 long start = System.currentTimeMillis();
 for (Integer key : map.keySet()) {
 map.get(key);
 }
 long end = System.currentTimeMillis();
 System.out.println("增强for循环,keySet迭代 -> " + (end - start) + " ms");
 
 
 start = System.currentTimeMillis();
 for (Entry<Integer, Integer> entry : map.entrySet()) {
 entry.getKey();
 entry.getValue();
 }
 end = System.currentTimeMillis();
 System.out.println("增强for循环,entrySet迭代 -> " + (end - start) + " ms");
 
 
 start = System.currentTimeMillis();
 Iterator<Integer> iterator = map.keySet().iterator();
 Integer key;
 while (iterator.hasNext()) {
 key = iterator.next();
 map.get(key);
 }
 end = System.currentTimeMillis();
 System.out.println("迭代器,keySet迭代 -> " + (end - start) + " ms");
 
 
 start = System.currentTimeMillis();
 Iterator<Map.Entry<Integer, Integer>> iterator1 = map.entrySet().iterator();
 Map.Entry<Integer, Integer> entry;
 while (iterator1.hasNext()) {
 entry = iterator1.next();
 entry.getKey();
 entry.getValue();
 }
 end = System.currentTimeMillis();
 
 System.out.println("迭代器,entrySet迭代 -> " + (end - start) + " ms");
 }
 }
 
 | 
排序
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 
 | Map<String, String> map = new HashMap<String, String>();
 map.put("a", "c");
 map.put("b", "b");
 map.put("c", "a");
 
 
 List<Map.Entry<String, String>> list = new ArrayList<Map.Entry<String, String>>(map.entrySet());
 
 Collections.sort(list, new Comparator<Map.Entry<String, String>>() {
 public int compare(Map.Entry<String, String> mapping1, Map.Entry<String, String> mapping2) {
 return mapping1.getKey().compareTo(mapping2.getKey());
 }
 });
 
 for (Map.Entry<String, String> mapping : list) {
 System.out.println(mapping.getKey() + " :" + mapping.getValue());
 }
 
 
 
 
 
 Map<String, String> map = new TreeMap<String, String>(new Comparator<String>() {
 public int compare(String obj1, String obj2) {
 return obj2.compareTo(obj1);
 }
 });
 map.put("a", "c");
 map.put("b", "b");
 map.put("c", "a");
 
 for (String key : map.keySet()) {
 System.out.println(key + " :" + map.get(key));
 }
 
 
 
 
 
 Map<String, String> map = new TreeMap<String, String>();
 map.put("a", "c");
 map.put("b", "b");
 map.put("c", "a");
 
 
 List<Map.Entry<String, String>> list = new ArrayList<Map.Entry<String, String>>(map.entrySet());
 
 Collections.sort(list, new Comparator<Map.Entry<String, String>>() {
 public int compare(Map.Entry<String, String> mapping1, Map.Entry<String, String> mapping2) {
 return mapping1.getValue().compareTo(mapping2.getValue());
 }
 });
 
 for (String key : map.keySet()) {
 System.out.println(key + " :" + map.get(key));
 }
 
 
 |