• Java 集合分页 Java List集合分页 List 分页 Java List集合笛卡尔积


    Java 集合分页 Java List集合分页 List 分页 Java List集合笛卡尔积

    一、前言

            在Java开发中,若单次展示的数据量太大,会造成程序响应缓慢,就需要用到 分页 功能,每一页展示一定量的数据,分多次展示 ... 那么在List集合中,如何实现 分页 功能呢?

            本文将以3种方式,分别是: subList 方法、Java8 Stream 、Lists.partition,实现 List集合的分页功能。

    二、代码实现

            1、假设有一个 list集合,元素如下:

    ArrayList list = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

            2、使用 subList 实现分页:

    1. /**@Description: subList 分页
    2. *
      1. 起始位置边界值处理: 当前页码 <= 0 情况处理; 当前页码 > 最大页码 情况处理
    3. *
      2. 终止位置边界值处理: 当前页码 <= 0 情况处理; 终止位置 <= 总记录数 情况处理
    4. * @param pageSize 每页显示的数量
    5. * @param pageNum 当前页码
    6. * @version v1.0
    7. * @author wu
    8. * @date 2022/7/31 11:44
    9. */
    10. private List subList(ArrayList list, int pageSize, int pageNum) {
    11. int count = list.size(); // 总记录数
    12. // 计算总页数
    13. int pages = count % pageSize == 0 ? count / pageSize : count / pageSize + 1;
    14. // 起始位置
    15. int start = pageNum <= 0 ? 0 : (pageNum > pages ? (pages - 1) * pageSize : (pageNum - 1) * pageSize);
    16. // 终止位置
    17. int end = pageNum <= 0 ? (pageSize <= count ? pageSize : count) : (pageSize * pageNum <= count ? pageSize * pageNum : count);
    18. return list.subList(start, end);
    19. }

            3、Java8 Stream 分页

    1. /**@Description: Java8 Stream 分页
    2. *
      1. 起始位置边界值处理: 同 subList 方法
    3. *
      2. 终止位置:无需处理,会自动处理边界问题
    4. * @param pageSize 每页显示的数量
    5. * @param pageNum 当前页码
    6. * @version v1.0
    7. * @author wu
    8. * @date 2022/7/31 11:49
    9. */
    10. private List subListJava8(ArrayList list, int pageSize, int pageNum) {
    11. int count = list.size(); // 总记录数
    12. // 计算总页数
    13. int pages = count % pageSize == 0 ? count / pageSize : count / pageSize + 1;
    14. // 起始位置
    15. int start = pageNum <= 0 ? 0 : (pageNum > pages ? (pages - 1) * pageSize : (pageNum - 1) * pageSize);
    16. // 终止位置
    17. int end = pageSize ;
    18. return list.stream().skip(start).limit(pageSize).collect(Collectors.toList());
    19. }

            4、使用 Lists 工具类的 partition 分页

    1. /**@Description: 使用 Lists 工具类的 partition 分页
    2. *
      1. 页码边界值处理:小于等于0,情况处理; 页码大于 (总页数-1) 情况处理
    3. *
      2. 总页数-1 ,原因是:list集合索引是从0开始的。
    4. * @param pageSize 每页显示的数量
    5. * @param pageNum 当前页码
    6. * @version v1.0
    7. * @author wu
    8. * @date 2022/7/31 11:55
    9. * @see com.google.common.collect.Lists#partition(java.util.List, int)
    10. */
    11. private List partition(ArrayList list, int pageSize, int pageNum) {
    12. // 将 List 按照 PageSzie 拆分成多个List
    13. Listextends List> partition = Lists.partition(list, pageSize);
    14. // 总页数
    15. int pages = partition.size();
    16. pageNum = pageNum <= 0 ? 0 : (pageNum <= (pages - 1) ? pageNum : (pages - 1));
    17. return partition.get(pageNum);
    18. }

    三、测试

            1、使用List的 subList 方法实现分页 测试:

    1. /**
    2. * @Description: 使用List的 subList 方法实现分页
    3. * @version v1.0
    4. * @author wu
    5. * @date 2022/7/31 10:43
    6. */
    7. @Test
    8. public void subListTest() {
    9. int pageSize = 3; // 每一页显示的数量
    10. int pageNum = 2; // 页码
    11. System.out.println(subList(list, pageSize, -2));
    12. System.out.println(subList(list, pageSize, 0));
    13. System.out.println(subList(list, pageSize, 1));// 第一页
    14. System.out.println(subList(list, pageSize, 2));
    15. System.out.println(subList(list, pageSize, 3));
    16. System.out.println(subList(list, pageSize, 4)); // 第四页数据
    17. System.out.println(subList(list, pageSize, 5)); // 第五页数据
    18. }

            2、使用 Java8 Stream 实现分页 测试:

    1. /**@Description: 使用 Java8 Stream 实现分页
    2. * @version v1.0
    3. * @author wu
    4. * @date 2022/7/31 11:44
    5. */
    6. @Test
    7. public void subListJava8Test() {
    8. int pageSize = 3; // 每一页显示的数量
    9. int pageNum = 2; // 页码
    10. System.out.println(subListJava8(list, pageSize, -2));
    11. System.out.println(subListJava8(list, pageSize, 0));
    12. System.out.println(subListJava8(list, pageSize, 1));// 第一页
    13. System.out.println(subListJava8(list, pageSize, 2));
    14. System.out.println(subListJava8(list, pageSize, 3));
    15. System.out.println(subListJava8(list, pageSize, 4)); // 第四页数据
    16. System.out.println(subListJava8(list, pageSize, 5)); // 第四页数据
    17. }

            3、Lists 工具类的 partition 分页 测试:

    1. @Test
    2. public void partitionTest() {
    3. int pageSize = 3; // 每一页显示的数量
    4. int pageNum = 2; // 页码
    5. System.out.println(partition(list, pageSize, -2));
    6. System.out.println(partition(list, pageSize, 0));
    7. System.out.println(partition(list, pageSize, 1));// 第一页
    8. System.out.println(partition(list, pageSize, 2));
    9. System.out.println(partition(list, pageSize, 3));
    10. System.out.println(partition(list, pageSize, 4)); // 第四页数据
    11. System.out.println(partition(list, pageSize, 5)); // 第五页数据
    12. System.out.println(partition(list, pageSize, 6)); // 第六页数据
    13. }

    四、总结

            1、以上是List集合实现分页的3种方式,在实际工作应用中,一般很少,都是在数据中实现好的分页,偶尔遇到实际要使用时,翻开文章,可以做到 “开箱即用”!

            2、注意点:本文分页案例中,都已经对 极端情况(边界值)处理,可以有效避免索引越界的情况,如下:

    • 开始位置: 当前页码值 <= 0 , 取值 第一页 ; 当前页码 > 总页数 , 取值 总页数
    • 结束位置:当前页码值 <= 0 ,则判断 每页显示数据 是否小于总记录数 ( pageSize <= count ? pageSize : count ); 当前页码 > 0 , 则判断 结束数量 是否小于等于 总记录数 ( pageSize * pageNum <= count ? pageSize * pageNum : count

            3、Lists 工具类,依赖 pom.xml :

    1. <dependency>
    2. <groupId>com.google.guavagroupId>
    3. <artifactId>guavaartifactId>
    4. <version>28.0-jreversion>
    5. dependency>

            4、补充一个 List 集合创建 笛卡尔积的方法:

    List> lists = Lists.cartesianProduct(list1, list2);

    关于List集合更多操作:

    Java List 集合取 交集、并集、差集、补集 Java集合取交集、Java集合并集_HaHa_Sir的博客-CSDN博客

  • 相关阅读:
    Golang笔记|Atomic
    Franka机械臂使用记录
    382.链表随机结点 | 398.随机数索引
    在线课堂分销商城小程序源码系统 带完整搭建教程
    【实验技术笔记】细胞表型检测之细胞凋亡(Hoechst染色 + PI染色 + TUNEL 染色 + Annexin V-PI 双染)
    CLWY权限管理(六)--- 权限实现
    华为云云耀云服务器L实例评测|急速上手,零基础,两小时完成搭建属于自己的个人网站
    【C++深入浅出】类和对象下篇
    “工会排队”模式:重塑电商生态的新力量
    基于Ambari下的大数据架构设计
  • 原文地址:https://blog.csdn.net/HaHa_Sir/article/details/126111838