/**
* @ClassName: Text2
* @Description: (集合的分页算法)
* @author Luhan
* @date 2017年3月16日 下午17:18:06
*/
public class Text1 {
private static List<Integer> date;
private static Integer PaseSize = 6;//显示多少条
private static Integer mPageNum = 30;//总条数

public static void main(String[] args) {
//传入的是显示第几页
showList(2);
}
/**
* 显示数据,分页显示list里面的数据
* @param pageNum 页数
*/
public static void showList(int pageNum){
date = new ArrayList<Integer>();
for (int i = 0; i < mPageNum; i++) {
date.add(i+1);
}
/**这里是决定一页只会显示6条
*
* for循环的左边 i等于的值
* 当是第一页的时候 1 对 0;索引应该从0开始
* 当是第二页的时候 2 对 6;索引应该从6开始
* 当是第三页的时候 3 对 12;索引应该从12开始
* 当是第四页的时候 4 对 18;索引应该从18开始
* .
* .
* .
* 以此类推
* 当是第n页的时候索引就应该是从(当前页数-1)*显示条数
*
*
*
* for循环的右边 i小于的值,这里假设只有20条数据
* 当是第一页的时候 1 对 0~6;右边的数应该为6
* 当是第一页的时候 2 对 6~12;右边的数应该为6
* 当是第一页的时候 3 对 12~18;右边的数应该为6
* 当是第一页的时候 4 对 18~20;右边的数应该为20,这里为什么会是20而不是24是因为我们只有20条数据,
* 显然i不能小于24,这样后面21、22、23根本就没有值,所以这应该是20
* 设 x = (当前页数-1)*显示条数;
* 最后得出右边的数值应该为:判断x是不是大于数据的总条数,如果大于就显示总条数,如果小于就显示x
* 所以这里我们可以使用三元运算符来解决就是下方的表达式
* ((pageNum-1)*PaseSize)+PaseSize > mPageNum ? mPageNum:((pageNum-1)*PaseSize)+PaseSize)
* 先判断下(当前是第几页-1乘以显示条数)是不是大于总条数,如果大于总条数就返回总条数,如果小于总条数则返回(当前是第几页-1乘以显示条数)
*/
List<Integer> newDate = new ArrayList<Integer>();
for (int i = (pageNum-1)*PaseSize; i < (
((pageNum-1)*PaseSize)+PaseSize > mPageNum ? mPageNum:((pageNum-1)*PaseSize)+PaseSize); i++) {
newDate.add(date.get(i));
}
System.out.println(">>>>>>>>>>第"+pageNum+"页的数据>>>>>>>>>>>>");
for (int i = 0; i < newDate.size(); i++) {
System.out.println(newDate.get(i));
}
}
}

如果想直接拿来使用的话,就直接复制下面的代码即可

/**
* 数据集合的分页方法,根据传入总共的数据跟页码,返回页码所需要显示多少条的数据
* <BR/>采用泛型的方法,即为,list中为什么类型的数据就返回什么类型的数据
* @param f 带有需要进行分页的数据集合
* @param pageNo 第几页
* @param dataSize 显示多少条数据
* @return 进过分页之后返回的数据
*/
public static <F> List<F> datepaging(List<F> f,int pageNo,int dataSize){
/*
* 经过测试发现当pageNo为0或者小于时,也就是第0页时,程序会报错,所以需要处理一下pageNo的值
*
* 先进行空值的判断,避免程序出现null异常
*
* 当pageNo的值小于等于0时,我们让它的值为1
*/
//参数的校验
if(f == null){//当传入过来的list集合为null时,先进行实例化
f = new ArrayList<F>();
}
if((Object)pageNo == null){//当传入过来的pageNo为null时,先进行赋值操作
pageNo = 1;
}
if((Object)dataSize == null){//当传入过来的dataSize为null时,先进行赋值操作
dataSize = 1;
}
if(pageNo <= 0){
pageNo = 1;
}

//记录一下数据一共有多少条
int totalitems = f.size();
//实例化一个接受分页处理之后的数据
List<F> afterList = new ArrayList<F>();
/*
* 进行分页处理,采用for循环的方式来进行处理
*
* 首先for循环中,i应该从哪里开始:i应该从 (当前是第几页 -1 乘以 条数) 开始
*
* 然后for循环应该到哪里结束,也就是i应该小于:判断(开始的索引+显示条数)是不是大于总条数,如果大于就是总条数,如果小于就是(开始的索引+显示条数)
*
* 然后让i++
*/

for
( int i = (pageNo-1)*dataSize;
i < (((pageNo -1)*dataSize) + dataSize >
totalitems ? totalitems:((pageNo -1)*dataSize) +dataSize);
i++) {
//然后将数据存入afterList中

afterList.add(f.get(i));
}

//然后将处理后的数据集合进行返回
return afterList;
}

List集合进行分页的更多相关文章

  1. PHP redis有序集合实现分页

    <?php //连接本地的 Redis 服务 $redis = new Redis(); $redis->connect('127.0.0.1', 6379); //设置 redis 字符 ...

  2. 针对list集合进行分页展示

    直接定义个工具类,代码如下: package com.jk51.modules.wechat.web.util; import java.util.Collections; import java.u ...

  3. C# ,通用内存集合对象分页、筛选(lambda那点事)

    通常呢我们需要翻页的数据大多都是从数据库中取,翻页.筛选.排序啥的都是通过SQL语句由数据库帮我搞定,那么有些需求没有数据库呢?或者有些数据只存在于内存中不存到数据库呢?怎么实现内存里面的对象集合的通 ...

  4. linq查询集合并分页展示数据

    private void Bind() { if (Request.QueryString["QuestionNo"] != null) { string QuestionNo = ...

  5. linq给list集合数据分页

    var lastlist= newlist.Skip(pageindex * pagesize).Take(pagesize);

  6. springboot集合pagehelper分页不生效的原因

    也可以

  7. Lind.DDD.Paging分页模块介绍

    回到目录 分页组件网上有很多,MVC.Pager,JSPager等,通过实现方式大体分为前端分页和后端分页,前端分页是前台对list内存本地集合进行分页,缺点就是在大数据情况下,内存占用过高:后端分页 ...

  8. 基于Metronic的Bootstrap开发框架经验总结(2)--列表分页处理和插件JSTree的使用

    在上篇<基于Metronic的Bootstrap开发框架经验总结(1)-框架总览及菜单模块的处理>介绍了Bootstrap开发框架的一些基础性概括,包括总体界面效果,以及布局.菜单等内容, ...

  9. c# 调用分页(控制器端的)与时间的格式

    1.在操作的model中: 2.在控制器中: , command.PageSize);//将从数据库获取到的集合进行分页 var gridModel = new DataSourceResult { ...

随机推荐

  1. Flex 布局教程学习

    转载自:阮一峰的网络日志(http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html) 网页布局(layout)是 CSS 的一个重点应用. 布局 ...

  2. MySQL中数据类型(char(n)、varchar(n)、nchar(n)、nvarchar(n)的区别)(转)

    一.第一种 char(n)和varchar(n)的区别: 在这里我们可以清楚的看到他们表面的区别就是前面是否有var,在这里解释一下var是什么意思,var代表“可变的”的意思 下面看个例子: )// ...

  3. MySQL 服务无法启动-问题处理

    症状:前一天在MySQL中删除了几个不用的数据库后登陆MySQL出现以下错误:   mysql -u root -p passwd   ERROR 2002 (HY000): Can't connec ...

  4. Unity -- Collider(碰撞器与触发器)

    (2d与3d的Collider可以相互存在,但是无法相互协作,如2d是无法检测3d的,反之,一样) 在目前掌握的情况分析,在Unity中参与碰撞的物体分2大块:1.发起碰撞的物体.2.接收碰撞的物体. ...

  5. 10.【nuxt起步】-引用mintui

    这时候我们完成了list.vue,但是怎么返回index.vue,这时候需要这个头部返回 1.我们使用现成的minu-ui,eleme的开源移动端 ,参考 https://www.cnblogs.co ...

  6. 细说Redis持久化机制

    概述 Redis不仅能够作为缓存来使用,也能够作为内存数据库. Redis作为内存数据库使用时.必需要解决一个问题:数据的持久性.有些将Redis作为缓存使用的场景也需要将缓存的数据持久化到存储介质上 ...

  7. SilverLight:基础控件使用(3)-DataGrid控件

    ylbtech-SilverLight-Basic-Control:基础控件使用(3)-DataGrid控件 DataGrid控件-后台绑定 自动生成表列 不自动生成表列 1.A,返回顶部Person ...

  8. 强大的开源网络侦查工具:IVRE

    IVRE简介 IVRE(又名DRUNK)是一款开源的网络侦查框架工具,IVRE使用Nmap.Zmap进行主动网络探测.使用Bro.P0f等进行网络流量被动分析,探测结果存入数据库中,方便数据的查询.分 ...

  9. 【OpenGL】OpenGL帧缓存对象(FBO:Frame Buffer Object) 【转】

    http://blog.csdn.net/xiajun07061225/article/details/7283929/ OpenGL Frame BufferObject(FBO) Overview ...

  10. 三维场景如何嵌入到PPT中展示?

    今天要跟大家一起交流的大体内容如标题所示,日常生活中,ppt已经成为人们工作学习生活中不可或缺的工具之一,那么三维场景是如何在ppt中加载展示的呢?请大家慢慢往下看. 1.创建命令按钮和web bro ...