最近看别人的source的时候发现了一个好代码,在这里备份一下,也给有需要的人用吧
public <T> List<List<T>> splitList(List<T> list, int pageSize)
{
int listSize = list.size();
int page = (listSize + (pageSize - 1)) / pageSize;
List<List<T>> listArray = new ArrayList<List<T>>();
for (int i = 0; i < page; i++)
{
List<T> subList = new ArrayList<T>();
for (int j = 0; j < listSize; j++)
{
int pageIndex = ((j + 1) + (pageSize - 1)) / pageSize;
if (pageIndex == (i + 1))
{
subList.add(list.get(j));
}
if ((j + 1) == ((j + 1) * pageSize))
{
break;
}
}
listArray.add(subList);
}
return listArray;
}
好吧,介于大家对上面的code蔑视,我在这里声明一下吧。
1.上面代码不是我写的,我上面说过了,是在看别人source的时候,感觉不错,以后可能会用到,这里留个备份。
2.上面代码是对有用的人写的,我替作者说说,如果大家感觉不满意,可以看个乐呵。没必要表示它不好吧。
3.我在这里举一个例子,这个方法还是有用的。当DAO处理量有限的时候,设定600,可是现在List有1800,
好吧,那么用上面的code分3页传到后台进行处理,也不用大家辛辛苦苦的写固定值了,设个数就ok了,感觉还是很方便的哦。
4.对,对于大数据比如上万条数据,Java JVM是会出现死机等恶劣状况,但是你为什么不用数据库呢,还用着方法干什么。code只为有需要的人写的。