参考链接: 如何在Java 8中打印Stream的元素
单元测试:
@Test
public void Test02(){
// 源
ArrayList<Integer> IdsSour = new ArrayList<>();
IdsSour.add(5);
IdsSour.add(1);
IdsSour.add(3);
IdsSour.add(2);
IdsSour.add(6);
IdsSour.add(4);
// 目标
List<Integer> IdsDes = new ArrayList<>();
System.out.println("============移除 4 ============");
IdsDes = (ArrayList<Integer>) IdsSour.stream().filter(id->id!=4).collect(Collectors.toList());
for (Integer id : IdsDes) {
System.out.println(id);
}
System.out.println("============移除 4 5 6============\n\n");
int[] ids = new int[]{4,5,6};
//按ID的 大小 从大到小 逆序 排列
IdsDes = (List<Integer>) IdsSour.stream().sorted(Comparator.reverseOrder()).collect(Collectors.toList());
for(int i = 0 ;i < ids.length ; i++){
int ret = ids[i];
//filter的写法 比 直接if判断再remove要含蓄的多,看起来舒服,但是效率不见得有for循环快
IdsDes = (ArrayList<Integer>) IdsDes.stream().filter(id->id!=ret).collect(Collectors.toList());
System.out.println("+++++++++++++++++第"+(i+1)+"次过滤后");
for (Integer id : IdsDes) {
System.out.println(id);
}
}
System.out.println("==================================");
//最后 按自然排序【默认】打印出IDsDes的内容
//先sorted再foreach -- 简单优雅 -- 优雅的背后 必定会有牺牲
IdsDes.stream().sorted().collect(Collectors.toList()).forEach(id->System.out.println(id));
}
运行效果: