您的位置:

用Java的HashMap初始化

一、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

HashMap map = new HashMap
   ();
map.put("key1", "value1");
map.put("key2", "value2");
map.put("key3", "value3");

   
  

2、通过Collections.singletonMap()方法初始化HashMap

此方法适用于只有一个键值对的情况。

HashMap map = new HashMap
   (Collections.singletonMap("key1", "value1"));

   
  

3、通过Arrays.asList()方法初始化HashMap

此方法适用于键值对个数固定的情况,最多支持10个键值对。

HashMap map = new HashMap
   () {{
        put("key1", "value1");
        put("key2", "value2");
        put("key3", "value3");
    }};

   
  

三、HashMap的遍历方式

1、使用for-each遍历key值

HashMap map = 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值

HashMap map = 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对

HashMap map = 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替代。