Efficient way to divide a list into lists of n size

You’ll want to do something that makes use of List.subList(int, int) views rather than copying each sublist. To do this really easily, use Guava‘s Lists.partition(List, int) method:

List<Foo> foos = ...
for (List<Foo> partition : Lists.partition(foos, n)) {
  // do something with partition
}

Note that this, like many things, isn’t very efficient with a List that isn’t RandomAccess (such as a LinkedList).

Leave a Comment