Odpowiedzi:
Zastosowanie 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 );
}
}
Należy pamiętać, że subList
zwraca widok elementów, więc jeśli chcesz, aby reszta listy kwalifikowała się do wyrzucania elementów bezużytecznych, skopiuj żądane elementy do nowego List
:
List<String> subItems = new ArrayList<String>(items.subList(0, 2));
Jeśli lista jest krótsza niż określony rozmiar, spodziewaj się wyjątku poza zakresem . Wybierz minimalną wartość żądanego rozmiaru i aktualny rozmiar listy jako indeks końcowy.
Na koniec zwróć uwagę, że drugi argument powinien być o jeden większy niż ostatni pożądany indeks.
Stream.limit
powinno załatwić sprawę ( docs.oracle.com/javase/8/docs/api/java/util/stream/… )
list.subList(100, list.size()).clear();
lub:
list.subList(0, 100);
list = list.subList(0, 100)
subList(100, list.size()).clear()
zadziała tylko wtedy, gdy lista ma zaimplementowaną metodę clear, na przykład jeśli utworzysz list
przez List<String> list = Arrays.asList(someString.split(","));
clear (), wyrzuci, UnsupportedOperationException
ponieważ list
będzie abstrakcyjny List
.
list.subList(n, list.size()).clear();
subList
, jak sugerowano w innych odpowiedziach, jest pierwszą, która przychodzi na myśl. Sugerowałbym również podejście strumieniowe .
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