一、HashMap基本概念
1、HashMap是什么
HashMap是Java中集合框架中的一种实现,可以用来存储键值对(key-value)。HashMap中的元素是没有顺序的,即不会按照插入的顺序保存数据。HashMap有一个默认的负载因子0.75,当HashMap的大小超过负载因子和初始容量的乘积时,就会进行扩容,以保证效率。
2、HashMap的特点
HashMap具备以下特点:
(1)HashMap中每个键值对都是独立的Java对象;
(2)HashMap中的键不能重复,即同一个键只对应一个值,如果同一个键存储了两个及以上的值,则后面的值会覆盖前面的值;
(3)可以通过get方法取出对应的值;
(4)可以通过iterator()方法遍历所有的键值对。
二、HashMap的初始化方式
1、通过new关键字初始化HashMap
HashMapmap = new HashMap (); map.put("key1", "value1"); map.put("key2", "value2"); map.put("key3", "value3");
2、通过Collections.singletonMap()方法初始化HashMap
此方法适用于只有一个键值对的情况。
HashMapmap = new HashMap (Collections.singletonMap("key1", "value1"));
3、通过Arrays.asList()方法初始化HashMap
此方法适用于键值对个数固定的情况,最多支持10个键值对。
HashMapmap = new HashMap () {{ put("key1", "value1"); put("key2", "value2"); put("key3", "value3"); }};
三、HashMap的遍历方式
1、使用for-each遍历key值
HashMapmap = new HashMap (); map.put("key1", "value1"); map.put("key2", "value2"); map.put("key3", "value3"); for (String key : map.keySet()) { System.out.println(key); }
2、使用for-each遍历value值
HashMapmap = new HashMap (); map.put("key1", "value1"); map.put("key2", "value2"); map.put("key3", "value3"); for (String value : map.values()) { System.out.println(value); }
3、使用Iterator遍历key-value对
HashMapmap = new HashMap (); map.put("key1", "value1"); map.put("key2", "value2"); map.put("key3", "value3"); Iterator > iterator = map.entrySet().iterator(); while (iterator.hasNext()) { Map.Entry entry = iterator.next(); System.out.println("key:" + entry.getKey() + ", value:" + entry.getValue()); }
四、HashMap的线程安全问题
HashMap在多线程情况下存在线程安全问题,因此在多线程情况下建议使用ConcurrentHashMap。
五、HashMap的注意事项
1、HashMap中的key需要重写equals()和hashCode()方法,保证key的唯一性和hash值的一致性;
2、HashMap中的value可以为null,但是key不能为null;
3、HashMap的默认初始容量是16,负载因子是0.75,当HashMap的元素个数达到容量*负载因子时,会自动扩容;
4、HashMap在扩容过程中会将原来的元素重新分配到新的容器中,所以无论是查询、添加、删除等操作都会产生额外的性能损耗;
5、HashMap是非线程安全的,如果涉及到多线程操作,应该使用ConcurrentHashMap替代。