我正在尝试将列表拆分为列表,其中每个列表的最大大小为4.
我想知道如何使用lambdas做到这一点.
目前我正在这样做的方式如下:
List<List<Object>> listofList = new ArrayList<>();
final int MAX_ROW_LENGTH = 4;
int startIndex =0;
while(startIndex <= listToSplit.size() )
{
int endindex = ( ( startIndex+MAX_ROW_LENGTH ) < listToSplit.size() ) ? startIndex+MAX_ROW_LENGTH : listToSplit.size();
listofList.add(new ArrayList<>(listToSplit.subList(startIndex,endindex)));
startIndex = startIndex+MAX_ROW_LENGTH;
}
UPDATE
似乎没有一种简单的方法可以使用lambdas来拆分列表.虽然所有的答案都非常受欢迎,但它们也是lambdas不简化事物的一个很好的例子.
解决方法
试试这种方法:
static <T> List<List<T>> listSplitter(List<T> incoming,int size) {
// add validation if needed
return incoming.stream()
.collect(Collector.of(
ArrayList::new,(accumulator,item) -> {
if(accumulator.isEmpty()) {
accumulator.add(new ArrayList<>(singletonList(item)));
} else {
List<T> last = accumulator.get(accumulator.size() - 1);
if(last.size() == size) {
accumulator.add(new ArrayList<>(singletonList(item)));
} else {
last.add(item);
}
}
},(li1,li2) -> {
li1.addAll(li2);
return li1;
}
));
}
System.out.println(
listSplitter(
Arrays.asList(0,1,2,3,4,5,6,7,8,9),4
)
);
另请注意,此代码可以进行优化,而不是:
new ArrayList<>(Collections.singletonList(item))
使用这一个:
List<List<T>> newList = new ArrayList<>(size); newList.add(item); return newList;