【深入Java基础】HashMap的基本用法

2022-09-02 13:21:16 浏览数 (1)

HashMap的基本用法

创建HashMap对象

HashMap<String,Integer> hashMap = new HashMap<>();

1

添加键值对

添加元素时,如果key已经存在,则返回旧value,并将新的value存到该key中;如果key不存在,则返回null

hashMap.put("aa",1);

hashMap.put("bb",2);

hashMap.put("cc",3);

1

2

3

put方法会覆盖原有的value,而另一种put方法不会覆盖:putIfAbsent(key,value)

hashMap.putIfAbsent("aa",4);

1

该方法首先会判断key是否存在,如果存在且value不为null,则不会覆盖原有的value,并返回原来的value;如果key不存在或者key的value为null,则会put进新值,并返回null。

另外,两种方法当key=null时,并不会抛出异常,而是按照一个特殊的方法进行存储。

删除元素

如果之前对相同key多次put,则可以移除key对应的旧value,而最新的value不受影响。(×)

remove(key):删除成功(存在key),返回被删除的key对应的value,否则返回null。

remove(key,value):删除成功(存在entry),返回true,否则返回false。

hashMap.remove("bb");

hashMap.remove("aa",5);

1

2

3

获取元素

对于获取元素,有get(key)和getOrDefault(key,defaultValue)(1.8之后)两种方法.

hashMap.get("cc")

1

getOrDefault在key不存在时,返回一个defaultValue。在没有该方法前需要这样写:

Integer bbValue = hashMap.containsKey("bb")?hashMap.get("bb"):-1;

1

有了getOrDefault可以这样写:

getOrDefault("aa",-1)//key=aa不存在,所以返回默认value -1

1

元素遍历

Iterator iterator = hashMap.keySet().iterator();

while (iterator.hasNext()){

String key = (String)iterator.next();

System.out.println(key "=" hashMap.get(key));

}

1

2

3

4

5

第二种遍历方法:

Iterator iterator1 = hashMap.entrySet().iterator();

while (iterator1.hasNext()){

Map.Entry entry = (Map.Entry) iterator1.next();

String key = (String) entry.getKey();

Integer value = (Integer) entry.getValue();

System.out.println(key "=" value);

}

1

2

3

4

5

6

7

判断key或value是否存在

hashMap.containsKey("aa");

hashMap.containsValue(1);

1

2

3

替换元素

replace方法用来替换元素。

hashMap.replace("ff",5);

1

对于存在的key,调用replace方法,会替换原来的value,并返回旧value,这和put的效果是一样的;对于不存在的key,replace方法什么都不做。这就是他和put的区别(put在key不存在时将新key-value加入map)。

0 人点赞