什么方法会截断列表(例如前 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
返回项目的 View ,因此如果您希望列表的其余部分有资格进行垃圾回收,您应该将您想要的项目复制到新的列表
:
List<String> subItems = new ArrayList<String>(items.subList(0, 2));
如果列表短于指定大小,则预期超出范围 exception .选择所需大小的最小值和列表的当前大小作为结束索引。
最后,请注意第二个参数应该比最后一个所需的索引大一。
关于java - 将列表截断为给定数量的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1279476/