java分頁之假分頁完成簡略的分頁器。本站提示廣大學習愛好者:(java分頁之假分頁完成簡略的分頁器)文章只能為提供參考,不一定能成為您想要的結果。以下是java分頁之假分頁完成簡略的分頁器正文
import java.util.Arrays; import java.util.Collections; import java.util.List; /** * @author shuang.gao Date: 2016/1/28 Time: 12:26 */ public class Pager<T> { /** * 每頁顯示條數 */ private int pageSize; /** * 原聚集 */ private List<T> data; private Pager(List<T> data, int pageSize) { if (data == null || data.isEmpty()) { throw new IllegalArgumentException("data must be not empty!"); } this.data = data; this.pageSize = pageSize; } /** * 創立分頁器 * * @param data 須要分頁的數據 * @param pageSize 每頁顯示條數 * @param <T> 營業對象 * @return 分頁器 */ public static <T> Pager<T> create(List<T> data, int pageSize) { return new Pager<>(data, pageSize); } /** * 獲得分頁後的數據 * * @param pageNum 頁碼 * @return 分頁後成果 */ public List<T> getPagedList(int pageNum) { int fromIndex = (pageNum - 1) * pageSize; if (fromIndex >= data.size()) { return Collections.emptyList(); } int toIndex = pageNum * 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 static void main(String[] args) { Integer[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12}; List<Integer> list = Arrays.asList(array); Pager<Integer> pager = Pager.create(list, 10); List<Integer> page1 = pager.getPagedList(1); System.out.println(page1); List<Integer> page2 = pager.getPagedList(2); System.out.println(page2); List<Integer> page3 = pager.getPagedList(3); System.out.println(page3); } }
假分頁,望文生義,不是真實的在數據庫裡停止過濾,而是從數據庫查詢以後,獲得全體成果,在展示的時刻做些四肢舉動。
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
/**
* @author shuang.gao Date: 2016/1/28 Time: 12:26
*/
public class Pager<T> {
/**
* 每頁顯示條數
*/
private int pageSize;
/**
* 原聚集
*/
private List<T> data;
private Pager(List<T> data, int pageSize) {
if (data == null || data.isEmpty()) {
throw new IllegalArgumentException("data must be not empty!");
}
this.data = data;
this.pageSize = pageSize;
}
/**
* 創立分頁器
*
* @param data 須要分頁的數據
* @param pageSize 每頁顯示條數
* @param <T> 營業對象
* @return 分頁器
*/
public static <T> Pager<T> create(List<T> data, int pageSize) {
return new Pager<>(data, pageSize);
}
/**
* 獲得分頁後的數據
*
* @param pageNum 頁碼
* @return 分頁後成果
*/
public List<T> getPagedList(int pageNum) {
int fromIndex = (pageNum - 1) * pageSize;
if (fromIndex >= data.size()) {
return Collections.emptyList();
}
int toIndex = pageNum * 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 static void main(String[] args) {
Integer[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12};
List<Integer> list = Arrays.asList(array);
Pager<Integer> pager = Pager.create(list, 10);
List<Integer> page1 = pager.getPagedList(1);
System.out.println(page1);
List<Integer> page2 = pager.getPagedList(2);
System.out.println(page2);
List<Integer> page3 = pager.getPagedList(3);
System.out.println(page3);
}
}
這是一個簡略的分頁器,道理很簡略,將從數據庫查詢的數據,傳入到分頁器裡,前往的是分好頁的聚集。
長處是兼容一切JDBC數據庫,缺陷是這類辦法不實用於年夜批量數據。
以上就是本文的全體內容,願望對年夜家的進修有所贊助。