Java优化后台分页

第一种情况:先查询出所有记录,再进行分页处理(分页中可以异步处理)

优化前:

List<String> list = Arrays.asList("1","2","3","4","5","6","7","8");
        for (int i = 0; ; i++) {
            List<String> list1 = list.stream().skip(i* 2L).limit(2).collect(Collectors.toList());
            System.out.print(list1.size()+",");
            if(list1.size()<2){
                break;
            }
            System.out.println(list1);
        }

优化后:

public class PaginationExample {  
    public static void main(String[] args) {  
        List<String> list = Arrays.asList("1", "2", "3", "4", "5", "6", "7", "8");  
        int pageSize = 2;  
        for (int i = 0; i < Math.ceil((double) list.size() / pageSize); i++) {  
            int start = i * pageSize;  
            int end = Math.min(start + pageSize, list.size());  
            List<String> subList = list.subList(start, end);  
            System.out.print(subList.size() + ",");  
            System.out.println(subList); 
        }  
    }  
}

优化说明:
使用 subList: 替换 stream 操作为 list.subList(),可以直接获取指定范围的子列表,这样可以减少流的创建和操作的开销。
计算页数: 使用 Math.ceil 来计算总页数,避免了不必要的无限循环。
合理计算结束索引: 使用 Math.min 确保结束索引不会超过列表的大小,从而避免了 IndexOutOfBoundsException。
这样优化后的代码既简洁又高效,适合处理大规模数据的分页处理。

第二种情况:不用获取总记录数,直接分页查询(一页一页的处理)

int pageNum=0;
int pageSize=5;
List<String> currentPageList;
do {
    //数据库分页查询
    currentPageList = mapper.selectByPage(pageNum * pageSize, pageSize);
    if (!currentPageList.isEmpty()) {
        System.out.println(currentPageList);
        pageNum++;
    }
} while (!currentPageList.isEmpty());
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值