【代码练习查漏补缺】HashMap常用方法

本文章转载于 赵斌Zz 的原创文章:https://blog.csdn.net/zhaobin0731/article/details/98962624


Map集合基于 键(key)/值(value)映射。每个键最多只能映射一个值。键可以是任何引用数据类型的值,不可重复;值可以是任何引用数据类型的值,可以重复;键值对存放无序。

HashMap的使用

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

HashMap常用方法

<1> put(K key, V value) 将键(key)/值(value)映射存放到Map集合中。
日常使用时通常需要考虑:键key是否已经存在于map,用if-else判断又显得很繁琐,因此可以配合getOrDefault()方法:获取指定 key 对应对 value,如果找不到 key ,则返回设置的默认值。

HashMap<Integer,Integer> map = new HashMap<>();
int key = 9;
int value = 10;
map.put(key, map.getOrDefault(key,0) + value);

上述代码实现了:如果map中不存在key,创建键值对key-value;如果存在,将值更新为 value + 原来的值 。

<2> get(Object key) 返回指定键所映射的值,没有该key对应的值则返回 null。

		HashMap<Integer,Integer> map = new HashMap<>();
        map.put(12,9);
        int i = map.get(12);

由于每个键对应一个值,一个值可能对应不同键,所以只提供了根据键获取值的方法。

<3> size() 返回Map集合中数据数量。

<4> clear() 清空Map集合

<5> isEmpty () 判断Map集合中是否有数据,如果没有则返回true,否则返回false

<6> remove(Object key) 删除Map集合中键为key的数据并返回其所对应value值。

<7> values() 返回Map集合中所有value组成的以Collection数据类型格式数据。

		HashMap<String,Integer> map=new HashMap<String,Integer>();
		map.put("zhaobin",70);
		map.put("bob", 60);
		map.put("bb", 6);
		System.out.println(map.values());

输出结果:

[70, 6, 60]

<8> keySet() 返回Map集合中所有key组成的Set集合。
由于map中键值对的存储是无序的,因此不能按照索引的方式遍历。

		HashMap<String,Integer> map=new HashMap<String,Integer>();
		map.put("zhaobin",70);
		map.put("bob", 60);
		map.put("bb", 6);
		System.out.println(map.keySet());

输出结果:

[zhaobin, bb, bob]

可以用于遍历map:

for(String key: map.keySet()){
	//对键key进行操作;
}

<9> containsKey(Object key) 判断集合中是否包含指定键,包含返回 true,否则返回false

<10> containsValue(Object value) 判断集合中是否包含指定值,包含返回 true,否则返回false。

<11> entrySet() 遍历集合,将Map集合每个key-value转换为一个Entry对象并返回由所有的Entry对象组成的Set集合

		Map<String, String> studentMap = new HashMap<String, String>();
		studentMap.put("002", "小王");
		studentMap.put("001", "小李");
		
		for (Entry<String, String> entry : studentMap.entrySet()) {
			String key = entry.getKey();
			String value = entry.getValue();
			System.out.println(key+":"+value);
		}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值