工作中对数据进行分页的场景很常见,分享一种分页方法
private static <T> List<T> startPage(List<T> list, Integer pageNumber, Integer pageSize) {
if (list == null || list.size() == 0) {
return new ArrayList<>();
}
int count = list.size(); // 记录总数
int pageCount = 0; // 页数
if (count % pageSize == 0) {
pageCount = count / pageSize;
} else {
pageCount = count / pageSize + 1;
}
int fromIndex = 0; // 开始索引
int toIndex = 0; // 结束索引
if (!pageNumber.equals(pageCount)) {
fromIndex = (pageNumber - 1) * pageSize;
toIndex = fromIndex + pageSize;
} else {
fromIndex = (pageNumber - 1) * pageSize;
toIndex = count;
}
return list.subList(fromIndex, toIndex);
}
如果对数据实时性要求不高,建议分页前对全量数据做缓存,避免每次获取全量数据导致接口耗时,特别是查询DB的操作。