在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+"处房产");
        }
    }
}

运行后效果:

 Java - 如何实现分拣存储? 随笔

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄