Map集合通过value获取key的几种方式
在java实际开发过程中我们进场会遇到通过value找到对应key的业务场景
下面博主列几种通过value找key的方法
1.普通循环
for(String key: map.keySet()){
String mapName = map.get(key);
if(mapName.indexOf(name)>=0){
c = key;
return c;
}
}
这里面其中关于indexOf判断条件大家可以自行修改为符合自己业务需要的逻辑
2.map自带的循环
map.forEach((k,v)->{
if(v.indexOf(name)>=0){
c = k;
return;
}
});
这种方式需要注意的是需要定义一个全局变量c来接收k,方法里面的局部变量是接收不了的。
//配合第一、二种方法使用通过map自带的循环以及lamdan表达式来完成获取值
private static String c = "";
整体代码结构如图所示
3.将map的key,value颠倒再通过key找value就可以获取到
return map.entrySet().stream().collect(Collectors.toMap(entity-> entity.getValue(),entity-> entity.getKey())).get(name);
简单说一下逻辑就是将map转为流然后再收集为map,其中对流的操作就是将原本的k,v结构颠倒,这时候我们就拿到了以原本value作为key的新map集合,然后在通过map自带的get方法就可以获取到对应的值。
备注:这三种方法中关于几个变量的解释:
name:map中的value值,即你想通过value找key的那个value值
map:我这些方法中的map是一个已知的map集合,目前我的是直接在代码中定义好的集合,大家可以调整代码修改为动态传参,逻辑是一样的。
总结:这三种方法都可以的,目前博主最终使用的是第三种方法。第三种方法需要注意的是原map中value值不能重复,重复后对流操作完收集为map的时候会报异常(“java.lang.IllegalStateException: Duplicate key”)。第一、二两种方法中需要注意的是如果value有多个重复值的时候,会“随机”返回一个key值,这个是由于Map的存值是无序的,大家想要有序的话可以将map定义为LinkedHashMap或者TreeMap。