Відповіді:
Використання 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()
спрацює лише в тому випадку, якщо в списку буде реалізований чіткий метод, наприклад, якщо ви створюєте list
команду List<String> list = Arrays.asList(someString.split(","));
clear (), 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