java工具类,list容器假分组

探讨了在业务逻辑中如何通过分页处理大量数据,同时利用缓存提高查询效率,减少重复查询带来的性能损耗。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

业务逻辑中需要查询全部的数据放入到list容器中,进行分组,以下提供假分组代码:

package chitChat_ht;

import java.util.Arrays;
import java.util.Collections;
import java.util.List;

public class ListGroupBy<T> {
	/** 原集合 */
	private List<T> data;

	/** 上一页 */
	private int lastPage;

	/** 当前页 */
	private int nowPage;

	/** 下一页 */
	private int nextPage;
	//
	/** 每页条数 */
	private int pageSize;

	/** 总页数 */
	private int totalPage;

	/** 总数据条数 */
	private int totalCount;

	public ListGroupBy(List<T> data, int nowPage, int pageSize) {
		if (data == null || data.isEmpty()) {
			throw new IllegalArgumentException("data must be not empty!");
		}

		this.data = data;
		this.pageSize = pageSize;
		/*
		 * this.totalPage = data.size()/pageSize; if(data.size()%pageSize!=0){
		 * this.totalPage++; }
		 */

		this.nowPage = nowPage;
		this.totalCount = data.size();
		this.totalPage = (totalCount + pageSize - 1) / pageSize;
		this.lastPage = nowPage - 1 > 1 ? nowPage - 1 : 1;
		this.nextPage = nowPage >= totalPage ? totalPage : nowPage + 1;

	}

	/**
	 * 得到分页后的数据
	 *
	 * @param pageNum
	 *            页码
	 * @return 分页后结果
	 */
	public List<T> getPagedList() {
		int fromIndex = (nowPage - 1) * pageSize;
		if (fromIndex >= data.size()) {
			return Collections.emptyList();// 空数组
		}
		if (fromIndex < 0) {
			return Collections.emptyList();// 空数组
		}
		int toIndex = nowPage * pageSize;
		if (toIndex >= data.size()) {
			toIndex = data.size();
		}
		return data.subList(fromIndex, toIndex);
	}

	public int getPageSize() {
		return pageSize;
	}

	public List<T> getData() {
		return data;
	}

	public int getLastPage() {
		return lastPage;
	}

	public int getNowPage() {
		return nowPage;
	}

	public int getNextPage() {
		return nextPage;
	}

	public int getTotalPage() {
		return totalPage;
	}

	public int getTotalCount() {
		return totalCount;
	}

	public static void main(String[] args) {
		Integer[] array = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22 };
		List<Integer> list = Arrays.asList(array);
		for (int i = 1; i <= list.size() / 10 + 1; i++) {
			ListGroupBy<Integer> listPageUtil = new ListGroupBy<Integer>(list, i, 10);
			List<Integer> pagedList = listPageUtil.getPagedList();
			System.out.println(pagedList);
		}
	}
}

当我使用这种加分也的时候,朋友问了一个问题,如果查询的list时间很长那么每次分页都要进行一次查询,效率不高,我这里处理的方案是,将结果查询出来放入缓存中,如果用户查询的是第一页的数据,刷新缓存内容,在进行分页,如果查询是后几页的内容,则直接取缓存数据,进行分页,当然缓存的时间需要根据业务逻辑进行调整,也可以异步刷新缓存内容

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值