前言
我们都知道map,知道通过map来实现key和value一一对应。
然而有的时候我们会需要通过两个或者多个key,来确定唯一的value,
或者通过一个key值找到多个value
一、两个key或多个key,确定一个value
例如:当前有两个key:key1,key2,值value1。我们想要通过key1和key2两个key都正确才能拿到value1
常见的有两种方法
1. key拼接
将每个key转换成String,然后通过将这几个字符串拼接成一个字符串来作为key。中间可以用符号隔开两个key以做区分。
即:
key3 = key1 + ":" +key2
map.put(key3,value1)
2.嵌套map
可以将数据结构定义为 Map<T,Map<T,T>> 。即通过两个map来实现。
这样就会实现严格意义上的两个key。
如:
Map<String,Map<String,String>> map = new HashMap<>();
Map<String,String> map1 = new HashMap<>();
map1.put(key2,value1);
map.put(key1,map1);
//查找value1
String value = map.get("key1").get("key2");
二、一个key对应多个value
可以利用Map< T, Set< T>>结构。
如key1 对应的值有value1,value2,value3
Map<String ,Set<String>> map = new HashMap<>();
Set<String> set = new HashSet<>();
set.add(value1);
set.add(value2);
set.add(value3);
map.put(key1, set);
总结
我们可以灵活的使用map,set等数据类型来组成各种key,value的对应关系。
当然,你也可以利用JSONObject等来实现key,value的对应