Ответы:
Использование List.subList
:
import java.util.*;
import static java.lang.Math.min;
public class T {
public static void main( String args[] ) {
List<String> items = Arrays.asList("1");
List<String> subItems = items.subList(0, min(items.size(), 2));
// Output: [1]
System.out.println( subItems );
items = Arrays.asList("1", "2", "3");
subItems = items.subList(0, min(items.size(), 2));
// Output: [1, 2]
System.out.println( subItems );
}
}
Вы должны иметь в виду, что subList
возвращает представление элементов, поэтому, если вы хотите, чтобы остальная часть списка имела право на сборку мусора, вы должны скопировать элементы, которые хотите, в новый List
:
List<String> subItems = new ArrayList<String>(items.subList(0, 2));
Если список короче указанного размера, ожидается исключение за пределами допустимого диапазона . Выберите минимальное значение желаемого размера и текущий размер списка в качестве конечного индекса.
Наконец, обратите внимание, что второй аргумент должен быть на единицу больше, чем последний желаемый индекс.
Stream.limit
должно помочь ( docs.oracle.com/javase/8/docs/api/java/util/stream/… )
list.subList(100, list.size()).clear();
или:
list.subList(0, 100);
list = list.subList(0, 100)
subList(100, list.size()).clear()
будет работать только в том случае, если в списке реализован его метод clear, например, если вы создаете с list
помощью List<String> list = Arrays.asList(someString.split(","));
clear (), будет throw, UnsupportedOperationException
поскольку list
будет абстрактным List
.
list.subList(n, list.size()).clear();
subList
, как предлагается в других ответах, первое, что приходит на ум. Я бы также предложил поточный подход .
source.stream().limit(10).collect(Collectors.toList()); // truncate to first 10 elements
source.stream().skip(2).limit(5).collect(Collectors.toList()); // discards the first 2 elements and takes the next 5