| 注册
请输入搜索内容

热门搜索

Java Linux MySQL PHP JavaScript Hibernate jQuery Nginx
BeulahGibbs
10年前发布

java数据列表 分页对象

[Java]代码    

import java.io.Serializable;  import java.util.ArrayList;  import java.util.Collection;  import java.util.List;    /**   * 分页   *    * from project: http://www.zyiqibook.com/201505/article0511162118297.html   */  public class Page<T> implements Serializable {     /**    *     */   private static final long serialVersionUID = -4906400433425467744L;     private static int DEFAULT_PAGE_SIZE = 20;     /**    *  每页记录条数    */   private int pageSize = DEFAULT_PAGE_SIZE;     /**    *  当前页第一条数据在List中的位置,从0开始    */   private long start;      private List<T> data;      private long totalCount; // 总记录数     /**    * 构造方法    */   public Page() {    this(0, 0, DEFAULT_PAGE_SIZE, new ArrayList<T>());   }     /**    * 默认构造方法.    *    * @param start  本页数据在数据库中的起始位置    * @param totalSize 数据库中总记录条数    * @param pageSize  本页容量    * @param data   本页包含的数据    */   public Page(long start, long totalSize, int pageSize, Collection<T> data) {    this.pageSize = pageSize;    this.start = start;    this.totalCount = totalSize;    this.data = new ArrayList<T>(data);   }     /**    * 取总记录数.    */   public long getTotalCount() {    return this.totalCount;   }     /**    * 取总页数.    */   public long getTotalPageCount() {    if (pageSize <= 0) {     return 0;    }    return (totalCount + pageSize - 1) / pageSize;   }     /**    * 取每页数据容量.    */   public int getPageSize() {    return pageSize;   }     /**    * 取当前页中的记录.    */   public List<T> getResult() {    return data;   }     /**    * 取该页当前页码,页码从1开始.    */   public int getCurrentPageNo() {    return (int)(start / pageSize + 1);   }     /**    * 该页是否有下一页.    */   public boolean hasNextPage() {    return this.getCurrentPageNo() < this.getTotalPageCount();   }     /**    * 该页是否有上一页.    */   public boolean hasPreviousPage() {    return this.getCurrentPageNo() > 1;   }     /**    * 获取任一页第一条数据在数据集的位置,每页条数使用默认值.    */   protected static int getStartOfPage(int pageNo) {    return getStartOfPage(pageNo, DEFAULT_PAGE_SIZE);   }     /**    * 获取任一页第一条数据在数据集的位置.    */   public static int getStartOfPage(int pageNo, int pageSize) {    return (pageNo - 1) * pageSize;   }     }