Java - 如何实现分拣存储?
在Java集合中,Map用于存储键值对<Key,Value>,可以通过Key来查找Value.当Key已经存在,则新的Value会覆盖原有的Value.
Key 和 Value 是"一对一"的关系. HashMap继承于AbstractMap类,实现了Map接口. 如果想存储某人名下的所有房产, 此时Key
SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。和Value 是"一对多"的关系, 那么该如何处理呢? 我们可以采用分拣存储的方法,来解决这个问题. 所谓的分拣存储其实就是将
相同Key所对应的Value 存储到一个容器中.
思路:
1 首先创建容器
2 然后判断新建容器中是否存在该用户 如果不存在则创建新容器并存储该用户
否则在原有Value基础上加1
3 最后获取用户名下的所有房产
package com.jd; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; public class House { public static void main(String[] args){ // 将用户名放入数组 String name = "bob,jack,sun,alison,bob,chris,jean,bob,alison,sun"; String[] name_arr= name.split("[\n\t\n.,;!]"); // 创建容器 Map<String, Integer> map = new HashMap<>(); for(String key:name_arr){ // 查看是否存在该用户名 if(!map.containsKey(key)){ // 不存在则创建新容器并放置该用户 map.put(key,1); }else{ // 存在则在原有Value基础上加1 map.put(key, map.get(key)+1); } } // 获取用户名下的所有房产 Set<String> keySet = map.keySet(); Iterator<String> it = keySet.iterator(); while (it.hasNext()){ String key = it.next(); Integer value = map.get(key); System.out.println("用户" +key +"有"+ value+"处房产"); } } }
运行后效果:

更多精彩