标签:end pageSize int List 截断 return originData 好用
List 分页截断工具说明
使用场景:需要把一个大 List 拆分出很多小 List ,然后再对每一部分进行分批处理,这里整个工具,因为每次都来写一个拆分不令阅读困难,也难维护,更容易出错。
上代码
/**
* 创建人 : sanri
* 创建时间 : 2018/9/1-15:12
* 功能 : list 拆分
*/
public class ListSplitIterator<T> implements Iterator<List<T>> {
protected List<T> originData;
private int position;
//默认每页 1000 条
private int pageSize = 1000;
public ListSplitIterator(List<T> originData){
if(originData == null){return ;}
this.originData = originData;
position = 0; //初始化位置为 0
}
public ListSplitIterator(List<T> originData, int pageSize) {
this(originData);
if(pageSize <= 0){
throw new IllegalArgumentException("pageSize 需要输入一个大于 0 的值");
}
this.pageSize = pageSize;
}
@Override
public boolean hasNext() {
return originData != null && !originData.isEmpty() && position < originData.size();
}
@Override
public List<T> next() {
if(hasNext()){
int start = position;
int end = position + pageSize ;
if(end >= originData.size()){
end = originData.size();
}
List<T> current = originData.subList(start,end);
position = end ;
return current;
}
return null;
}
@Override
public void remove() {
throw new RuntimeException("未实现 remove 方法");
}
public int size(){
return originData == null ? 0 : ( originData.size() - 1) / pageSize + 1;
}
public List<T> get(int index){
if(originData == null) return null;
int start = index * pageSize;
int end = (index + 1 ) * pageSize;
if (end >= originData.size()){
end = originData.size();
}
return originData.subList(start,end);
}
/**
* 获取当前位置
* @return
*/
public long position() {
return position;
}
}
标签:end,pageSize,int,List,截断,return,originData,好用 来源: https://blog.csdn.net/sanri1993/article/details/100604512
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。