欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Java 中 List 和 Map 的切割工具

程序员文章站 2022-04-22 13:47:49
...

在项目开发中会遇到对结果集List or Map要做业务切割。

如下两个工具分别对 List 和 Map 按照指定大小进行切割:

 /**
     * 将map切成段     *
     * @param chunkMap 被切段的 map
     * @param chunkNum 每段的大小
     * @param <k>      map 的 key类 型
     * @param <v>      map 的value 类型
     * @return List
     */
    public static <k, v> List<Map<k, v>> mapChunk(Map<k, v> chunkMap, int chunkNum) {
        if (chunkMap == null || chunkNum <= 0) {
            List<Map<k, v>> list = new ArrayList<>();
            list.add(chunkMap);
            return list;
        }
        Set<k> keySet = chunkMap.keySet();
        Iterator<k> iterator = keySet.iterator();
        int i = 1;
        List<Map<k, v>> total = new ArrayList<>();
        Map<k, v> tem = new HashMap<>();
        while (iterator.hasNext()) {
            k next = iterator.next();
            tem.put(next, chunkMap.get(next));
            if (i == chunkNum) {
                total.add(tem);
                tem = new HashMap<>();
                i = 0;
            }
            i++;
        }
        if (!CollectionUtils.isEmpty(tem)) {
            total.add(tem);
        }
        return total;
    }


    /**
     * 将 list 切成段 
     * @param chunkNum 每段的大小
     * @param list
     * @return map 每一 Kye 中有 chunkNum 条数据
     */
    public static LinkedHashMap groupList(List list, int chunkNum) {
        int listSize = list.size();
        int toIndex = chunkNum;
        LinkedHashMap map = new LinkedHashMap();
        int keyToken = 0;
        for (int i = 0; i < listSize; i += chunkNum) {
            if (i + chunkNum > listSize) {
                toIndex = listSize - i;
            }
            List newList = list.subList(i, i + toIndex);
            map.put("keyName" + (keyToken + 1), newList);
            keyToken++;
        }
        return map;
    }

 

相关标签: 后台