[java] 목록을 주어진 요소 수로 자릅니다.

목록 (예 : 처음 100 개 요소)을 자르고 다른 요소를 삭제하는 방법은 무엇입니까 (개별 요소를 반복하지 않고)?



답변

사용 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));

목록이 지정된 크기보다 짧으면 범위를 벗어난 예외가 발생 합니다. 원하는 크기의 최소값과 끝 인덱스로 목록의 현재 크기를 선택합니다.

마지막으로 두 번째 인수는 원하는 마지막 인덱스보다 하나 더 많아야합니다.


답변

list.subList(100, list.size()).clear();

또는:

list.subList(0, 100);


답변

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


답변