這篇文章將為大家詳細講解有關使用JAVA8中API實現分頁的案例,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
使用JAVA8的API可以實現分頁,在數據量相對穩定的情況下,可以查出所有數據,配合緩存使用
import java.util.ArrayList; import java.util.List; import java.util.Optional; /** * @version 1.0 * @author levelmini * @param <T> */ public class Page<T> { private int current_page; private int size; private int total_page; private int total_sum; private transient List<T> instanceList;//Gson不序列化transient字段 private List<T> currentPageData; private transient Optional<List<T>> op; public Page(List<T> instanceList,int size) { this.size = size; setInstanceList(instanceList); } public int getCurrent_page() { return current_page; } public void setCurrent_page(int current_page) { this.current_page = current_page<1?1:current_page>this.total_page?this.total_page:current_page; setCurrentPageData(currentPageData()); } public int getSize() { return size; } public void setSize(int size) { this.size = size; } public int getTotal_page() { return total_page; } public int getTotal_sum() { return total_sum; } public List<T> getInstanceList() { return instanceList; } public void setInstanceList(List<T> instanceList) { this.op= Optional.ofNullable(instanceList); this.instanceList = op.orElse(new ArrayList<T>()); this.total_sum = this.instanceList.size(); this.total_page =(int) Math.ceil(1.0*this.total_sum/this.size); } public void setCurrentPageData(List<T> currentPageData) { this.currentPageData = currentPageData; } public List<T> getCurrentPageData(){ return this.currentPageData; } private List<T> currentPageData(){ if(this.size==0 || this.total_page == 1){ return this.instanceList; } List<T> currentPageData = new ArrayList<T>(); instanceList.stream().skip((this.current_page-1)*this.size).limit(this.size).forEach(e->currentPageData.add(e)); return currentPageData; } }
用法:
List<News> newsList = newsService.findAll(); Page<News> page = new Page<>(newsList, size); page.setCurrent_page(current_page); return JsonUtil.toJson(page,"yyyy-MM-dd");
關于使用JAVA8中API實現分頁的案例就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。