ytt*_*rrr 28 java java-8 java-stream
我想知道是否有替代方案
List<X> lastN = all.subList(Math.max(0, all.size() - n), all.size());
Run Code Online (Sandbox Code Playgroud)
用流?
Tag*_*eev 22
自定义收集器可以这样写:
public static <T> Collector<T, ?, List<T>> lastN(int n) {
return Collector.<T, Deque<T>, List<T>>of(ArrayDeque::new, (acc, t) -> {
if(acc.size() == n)
acc.pollFirst();
acc.add(t);
}, (acc1, acc2) -> {
while(acc2.size() < n && !acc1.isEmpty()) {
acc2.addFirst(acc1.pollLast());
}
return acc2;
}, ArrayList::new);
}
Run Code Online (Sandbox Code Playgroud)
并像这样使用它:
List<String> lastTen = input.stream().collect(lastN(10));
Run Code Online (Sandbox Code Playgroud)
Jor*_*lla 19
在丢弃流的前n个元素后,返回由此流的其余元素组成的流.如果此流包含少于n个元素,则将返回空流.
all.stream().skip(Math.max(0, all.size() - n)).forEach(doSomething);
Run Code Online (Sandbox Code Playgroud)