JAVA 通过value获取Map中key的三种方法

简介

我们都知道Map是存放键值对<Key,Value>的容器,知道了Key值,使用方法Map.get(key)能快速获取Value值。然而,有的时候我们需要反过来获取,知道Value值,求Key值。
本文将用实例介绍三种方法,通过传入Value值,获取得到Key值。

方法描述

循环法

循环法就是通过遍历Map里的Entry,一个个比较,把符合条件的找出来。

@Test
public void loop() {
	Map<String, Integer> map = new HashMap<>();
	map.put("A", 1);
	map.put("B", 2);
	map.put("C", 3);
	map.put("D", 2);
	//找到一个值
	getKeyByLoop(map, 1);
	//找到多个值
	getKeysByLoop(map, 2);
	//找不到
	getKeyByLoop(map, 4);
}

private <K, V> Set<K> getKeysByLoop(Map<K, V> map, V value) {
	Set<K> set = Sets.newHashSet();
	for (Map.Entry<K, V> entry : map.entrySet()) {
		if (Objects.equals(entry.getValue(), value)) {
			set.add(entry.getKey());
		}
	}
	return set;
}

Stream方法

Stream总是在多种集合操作上都能提供优雅直观的方法,易写但不易读。通过一个过滤器,即可把满足相等条件的值取出来。

@Test
public void stream() {
	Map<String, Integer> map = ImmutableMap.of("A", 1, "B", 2, "C", 3, "D", 2);
	getKeysByStream(map, 2);
}

private <K, V> Set<K> getKeysByStream(Map<K, V> map, V value) {
	return map.entrySet()
		.stream()
		.filter(kvEntry -> Objects.equals(kvEntry.getValue(), value))
		.map(Map.Entry::getKey)
		.collect(Collectors.toSet());
}

Apache Commons Collections的BidiMap

添加依赖:

<dependency>
	<groupId>org.apache.commons</groupId>
	<artifactId>commons-collections4</artifactId>
	<version>4.0</version>
</dependency>

Apache Commons Collections提供了双向Map的类BidiMap。它提供了getKey(value)方法返回Key值,且兼容get(key)方法用以获取value。

@Test
public void apacheCommons() {
	BidiMap<String, Integer> bidiMap = new DualHashBidiMap<>();
    bidiMap.put("A", 1);
    bidiMap.put("B", 3);
    bidiMap.put("B", 2);
    bidiMap.put("E", 9);
    bidiMap.put("C", null);
    bidiMap.put("D", 2);
    System.out.println(bidiMap.getKey(1)); // A
    System.out.println(bidiMap.getKey(2)); // D
    System.out.println(bidiMap.getKey(3)); // null
    System.out.println(bidiMap.getKey(4)); // null
    System.out.println(bidiMap.getKey(null)); // C
    System.out.println(bidiMap.getKey(9)); // E
    
	System.out.println(bidiMap.getOrDefault("A",null)); // 1
    System.out.println(bidiMap.getOrDefault("B",null)); // null
    System.out.println(bidiMap.getOrDefault("C",null)); // null
    System.out.println(bidiMap.getOrDefault("D",null)); // 2
    System.out.println(bidiMap.getOrDefault("E",null)); // 9
   
    System.out.println(bidiMap); // {A=1, C=null, D=2, E=9}
}

从代码执行可知,如果出现key或者value相同的情况,前者会被后者替代。

总结

本文介绍了三种通过Value值获取Map中的Key值的方法,分别是循环法、Stream、Apache Commons Collections,这三种方法类似但不尽相同。

  1. 循环法和使用Stram本质上都是要遍历的,如果一个Map经常需要反向取Key值,则不建议使用,可以考虑Apache Commons提供的双向Map;
  2. 双向Map其实是一种空间换取时间的思想,虽然能较快的找到满足条件的Key值,但它也使用了更多的空间来储存双向Map;
  3. 双向Map并不支持多对一的关系。

如何选择,就看具体需求来取舍了。

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值