关于HashMap根据Value获取Key

简介:

Map中是一个key有且只有一个value.

但是一个value可以对应多个key值.

一般都是通过key,然后map.get(key)获得到value.

如果想要反向想通过value获得key的值,提供一下两种方法:

方法一:

复制代码
 1 package cn.itcast.mapgetkey;
 2 
 3 import java.util.ArrayList;
 4 import java.util.HashMap;
 5 import java.util.List;
 6 
 7 public class HashMapDemo {
 8     //根据value值获取到对应的一个key值
 9     public static String getKey(HashMap<String,String> map,String value){
10         String key = null;
11         //Map,HashMap并没有实现Iteratable接口.不能用于增强for循环.
12         for(String getKey: map.keySet()){
13             if(map.get(getKey).equals(value)){
14                 key = getKey;
15             }
16         }
17         return key;
18         //这个key肯定是最后一个满足该条件的key.
19     }
20     
21     //根据value值获取到对应的所有的key值
22     public static List<String> getKeyList(HashMap<String,String> map,String value){
23         List<String> keyList = new ArrayList();
24         for(String getKey: map.keySet()){
25             if(map.get(getKey).equals(value)){
26                 keyList.add(getKey);
27             }
28         }
29         return keyList;
30     }
31     
32     public static void main(String[] args) {
33         HashMap<String,String> map = new HashMap();
34         map.put("CHINA", "中国");
35         map.put("CN", "中国");
36         map.put("AM", "美国");
37         //获取一个Key
38         System.out.println("通过value获取Key:"+getKey(map,"中国"));//输出"CN"
39         System.out.println("通过value获取Key:"+getKey(map,"美国"));//输出"AM"
40         //获得所有的key值
41         System.out.println("通过value获取所有的key值:"+getKeyList(map,"中国"));//输出"[CHINA, CN]"
42         
43     }
44 }
复制代码

  方法二:

复制代码
 1 package cn.itcast.mapgetkey2;
 2 
 3 import java.util.ArrayList;
 4 import java.util.HashMap;
 5 import java.util.Iterator;
 6 import java.util.Map;
 7 import java.util.Map.Entry;
 8 import java.util.Set;
 9 
10 public class MapValueGetKey {
11     HashMap<String, String> map = null;
12 
13     public MapValueGetKey(HashMap<String, String> map) {
14         this.map = map;
15     }
16 
17     public static void main(String[] args) {
18         HashMap<String, String> map = new HashMap<String, String>();
19         map.put("1", "a");
20         map.put("2", "b");
21         map.put("3", "c");
22         map.put("4", "c");
23         map.put("5", "e");
24         MapValueGetKey mapValueGetKey = new MapValueGetKey(map);
25         System.out.println(mapValueGetKey.getKey("c"));//输出[3, 4]
26     }
27 
28     private ArrayList<String> getKey(String value) {
29         ArrayList<String> keyList = new ArrayList<String>();
30         String key = null;
31         Set<Entry<String, String>> set = map.entrySet();// entrySet()方法就是把map中的每个键值对变成对应成Set集合中的一个对象.
32         // set对象中的内容如下:[3=c, 2=b, 1=a, 5=e, 4=c]
33         Iterator it = set.iterator();
34         while (it.hasNext()) {
35             Map.Entry<String, String> entry = (Map.Entry<String, String>) it.next();
36             // entry中的内容就是set集合中的每个对象(map集合中的一个键值对)3=c....
37             // Map.Entry就是一种类型,专值map中的一个键值对组成的对象.
38             if (entry.getValue().equals(value)){
39                 key = (String) entry.getKey();
40                 keyList.add(key);
41             }
42         }
43         return keyList;
44     }
45 }
复制代码

 

 


本文转自SummerChill博客园博客,原文链接:http://www.cnblogs.com/DreamDrive/p/4673183.html,如需转载请自行联系原作者

相关文章
|
14天前
|
存储 安全 Java
HashMap的详细解读
HashMap的详细解读
35 0
|
5月前
|
存储
HashMap HashTable ConcurrentMap 中key value是否可以为null
HashMap HashTable ConcurrentMap 中key value是否可以为null
44 0
|
8月前
|
存储 安全 算法
|
算法 Java 程序员
Java HashMap 在获得 Key 的 Hash 值的时候用的是什么算法
Java 在 HashMap Key 的 Hash 值的时候用的的是自己 Object 中的 hashCode() 算法。
141 0
Map中的entrySet();跟keySet();的区别是什么
Map中的entrySet();跟keySet();的区别是什么
116 0
|
算法 安全 Java
HashMap,难的不在Map,而在Hash
HashMap,难的不在Map,而在Hash
97 0
|
存储 Linux C++
map和hash_map的区别
map和hash_map的区别
148 0
|
存储 算法 安全
HashMap中hash方法的原理
你知道HashMap中hash方法的具体实现吗?你知道HashTable、ConcurrentHashMap中hash方法的实现以及原因吗?你知道为什么要这么实现吗?你知道为什么JDK 7和JDK 8中hash方法实现的不同以及区别吗?如果你不能很好的回答这些问题,那么你需要好好看看这篇文章。文中涉及到大量代码和计算机底层原理知识。绝对的干货满满。整个互联网,把hash()分析的如此透彻的,别无二家。
HashMap中hash方法的原理
HashMap 详解五
红黑树性质 红黑树是平衡二叉树的一种, 但是它的平衡因子是可以大于 1 红黑树的节点要么是红色, 要么是黑色, 这里的红黑色只是用来区分的一种方式, 为了定义规则 根节点一定是黑色 叶子节点也是黑色, 实际上叶子节点都是由 NULL 组成 红色节点的子节点是黑色 根节点到叶子节点的路径都.
1059 0