如何分块 java 中的字符串集合
How to chunk a Collection of Strings in java
我有一个字符串类型的集合,其中包含 0 到 10k 之间的任意值。
我正在寻找一种优雅或可重用的方法来编写一种方法,该方法采用 String 类型的集合和批处理大小,并将集合拆分为提供的批处理大小的较小块。
我能想到的最佳解决方案是:
private static <T> Collection<Collection<T>> getBatches( List<T> collection, int batchSize ){
return IntStream.iterate(0, i -> i < collection.size(), i -> i + batchSize)
.mapToObj(i -> collection.subList(i, Math.min(i + batchSize, collection.size())))
.collect(Collectors.toList());
}
一些担忧:
- 我想接收一个字符串类型的集合,return一个字符串类型的集合集合或一个字符串类型的集合列表。
- 我想知道是否存在此逻辑不适用于的缺点或边缘情况。
看看这个例子的想法:
final List<Integer> numbers = Arrays.asList(1,2,3,4,5,6,7);
final int chunkSize = 3;
final AtomicInteger counter = new AtomicInteger();
final Collection<List<Integer>> result = numbers.stream()
.collect(Collectors.groupingBy(it ->
counter.getAndIncrement() / chunkSize))
.values();
System.out.println(result);
我有一个字符串类型的集合,其中包含 0 到 10k 之间的任意值。 我正在寻找一种优雅或可重用的方法来编写一种方法,该方法采用 String 类型的集合和批处理大小,并将集合拆分为提供的批处理大小的较小块。
我能想到的最佳解决方案是:
private static <T> Collection<Collection<T>> getBatches( List<T> collection, int batchSize ){
return IntStream.iterate(0, i -> i < collection.size(), i -> i + batchSize)
.mapToObj(i -> collection.subList(i, Math.min(i + batchSize, collection.size())))
.collect(Collectors.toList());
}
一些担忧:
- 我想接收一个字符串类型的集合,return一个字符串类型的集合集合或一个字符串类型的集合列表。
- 我想知道是否存在此逻辑不适用于的缺点或边缘情况。
看看这个例子的想法:
final List<Integer> numbers = Arrays.asList(1,2,3,4,5,6,7);
final int chunkSize = 3;
final AtomicInteger counter = new AtomicInteger();
final Collection<List<Integer>> result = numbers.stream()
.collect(Collectors.groupingBy(it ->
counter.getAndIncrement() / chunkSize))
.values();
System.out.println(result);