Java--ListUtil工具类,实现将一个大列表,拆分成指定长度的子列表

文章目录

前言

在项目中有时会出现列表很大,无法一次性批量操作,我们需要将列表分成指定大小的几个子列表,一份一份进行操作,本文提供这样的工具类实现这个需求。

实现代码

以下为ListUtil工具类代码实现:

java 复制代码
public class ListUtils {
    public static <T> List<List<T>> partition(final List<T> list, final int size) {
        if (list == null) {
            throw new NullPointerException("List must not be null");
        }
        if (size <= 0) {
            throw new IllegalArgumentException("Size must be greater than 0");
        }
        return new Partition<>(list, size);
    }
    private static class Partition<T> extends AbstractList<List<T>> {
        private final List<T> list;
        private final int size;
       /**
        * 
        * @param list 传入的列表
        * @param size 指定的长度,每size个数据切割为一个子列表
        */
        private Partition(final List<T> list, final int size) {
            this.list = list;
            this.size = size;
        }

       /**
        * 获取按指定长度拆分后,索引位置的子列表
        * @param index
        * @return
        */
        @Override
        public List<T> get(final int index) {
            //获取拆分后子列表的个数
            final int listSize = size();
            if (index < 0) {
                throw new IndexOutOfBoundsException("Index " + index + " must not be negative");
            }
            if (index >= listSize) {
                throw new IndexOutOfBoundsException("Index " + index + " must be less than size " +
                        listSize);
            }
            final int start = index * size;
            final int end = Math.min(start + size, list.size());
            //返回子列表
            return list.subList(start, end);
        }
        @Override
        public int size() {
            //(传入列表总长度/指定的长度)向上取整,即为拆分后子列表的个数
            return (int) Math.ceil((double) list.size() / (double) size);
        }
        @Override
        public boolean isEmpty() {
            return list.isEmpty();
        }
    }
}
执行结果
  1. 在上述类里写个main方法用以测试结果。

    java 复制代码
      public static void main(String[] args) {
         List<String> list=new ArrayList<String>();
         for (int i = 0; i <= 2000; i++) {
    	      list.add(i+"");
         }
     	 //将list每2000条数据拆分成一个子列表
      	 List<List<String>> partition = ListUtils.partition(list, 2000);
    	 System.out.println("将list每2000条数据拆分成一个子列表:");
     	 System.out.println("子列表个数:"+partition.size());
     	 System.out.println("第二个子列表的内容:");
    	 partition.get(1).forEach(System.out::print);
         System.out.println("-------------------------------------------------------");
         System.out.println("将list每10条数据拆分成一个子列表:");
         List<List<String>> partition1 = ListUtils.partition(list, 10);
         System.out.println("子列表个数:"+partition1.size());
         System.out.println("第三个子列表的内容:");
    	 partition1.get(2).forEach(s -> {
    	      System.out.print(s+" ");
         });
      }
  2. 执行main方法,得到结果如下:

  3. 分析结果

    将list每2000条数据拆分成一个子列表后,子列表个数为2,第一个子列表里的内容{0,1,...,1998,1999},第二个子列表的内容为{2000}。

    将list每10条数据拆分成一个子列表后,子列表个数为201,分别为{0,1,...,8,9},......,{1990,1991,...,1998,1999},{2000}。

    结果符合我们的要求,通过这个工具类,我们实现了所需功能。

相关推荐
ℳ₯㎕ddzོꦿ࿐10 分钟前
Java集成Zxing和OpenCV实现二维码生成与识别工具类
java·opencv
雪落山庄15 分钟前
LeetCode100题
java·开发语言·数据结构
码熔burning35 分钟前
【MQ篇】RabbitMQ之发布订阅模式!
java·分布式·rabbitmq·mq
XiaoLeisj43 分钟前
【设计模式】深入解析代理模式(委托模式):代理模式思想、静态模式和动态模式定义与区别、静态代理模式代码实现
java·spring boot·后端·spring·设计模式·代理模式·委托模式
李少兄1 小时前
解决Spring Boot版本冲突导致的`NoSuchFieldError`
java·spring boot·后端
pwzs1 小时前
常见的 Spring Boot 注解汇总
java·spring boot·后端·spring
小凡敲代码1 小时前
美团Java后端二面面经!
java·程序员·java面试·java面试题·java开发·java场景题·美团java后端
雾月552 小时前
LeetCode 1780 判断一个数字是否可以表示成三的幂的和
java·数据结构·算法·leetcode·职场和发展·idea
ゞ 正在缓冲99%…2 小时前
leetcode201.数字范围按位与
java·数据结构·算法·位运算
神仙别闹2 小时前
基于Java(JSP)+MySQL实现深度学习的音乐推荐系统
java·深度学习·mysql