【java高级】stream流的基本用法(一)

简介: 【java高级】stream流的基本用法(一)

Filter

public class FilterStreamDemo {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("aa");
        list.add("bb");
        list.add("cc");
        list.add("dd");
        setFilter(list);
    }
    public static void setFilter(List<String> list){
        list=list.stream().filter(e->e.equals("aa")).collect(Collectors.toList());// 过滤list中的元素等于aa的留下
        list.forEach(System.out::println);
    }
}

执行结果

分析

filter是将每个list中的元素做 集合.stream().filter(条件)的筛选,条件为true的留下,另外list筛选并没有修改list的元素,只是返回的符合筛选条件的元素.collect(Collectors.toList());就是将筛选的元素重新转换为list。

如何在jvm中实现sql的where条件的效果

public class FilterStreamDemo {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("aa");
        list.add("bb");
        list.add("cc");
        list.add("dd");
        String query="dd";
        String query1="aa";
        setFilter(list,query,query1);
    }
    public static void setFilter(List<String> list,String query,String query1){
        list=list.stream().filter(e -> query == null ? true : e.equals(query)).filter(e -> query1 == null ? true : e.equals(query1)).collect(Collectors.toList());
        list.forEach(System.out::println);
    }
}

分析:因为每个元素筛选时,如果为true就留下,所以当参数为null时,就全部为true,这样就自动取消这个条件了。

e -> query == null ? true : e.equals(query))

范例 :stream流模仿sql where条件+模糊查询

  projectSortList=projectList.stream()
                            .filter(e->query.getId()==null||isContaint(e.getId(),query.getId()))
                            .filter(e->query.getProjectName()==null||isContaint(e.getProjectName(),query.getProjectName()))
                            .filter(e->query.getProjectStatus()==null||query.getProjectStatus().equals(e.getProjectStatus()))
                            .filter(e->query.getBusinessId()==null||query.getBusinessId().equals(e.getBusinessId()))
                            .filter(e->query.getProjectType()==null||isContaint(e.getProjectType(),query.getProjectType()))
                            .filter(e->query.getBusinessName()==null||isContaint(e.getBusinessName(),query.getBusinessName()))
                            .filter(e->query.getCustomer()==null||query.getCustomer().equals(e.getCustomer()))
                            .filter(e->query.getCreateUser()==null||query.getCreateUser().equals(e.getCreateUser()))
                            .filter(e->query.getProjectManager()==null||query.getProjectManager().equals(e.getProjectManager()))
                            .collect(Collectors.toList());

 public Boolean isContaint(String e,String query){
        return e.contains(query);
    }   

Map

public class MapStreamDemo {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("aa");
        list.add("bb");
        list.add("cc");
        list.add("dd");

        setUp(list);// 变大写字母
    }

    public static void setUp(List<String> list){
        list=list.stream().map(String::toUpperCase).collect(Collectors.toList());
        list.forEach(System.out::println);
    }
}

sorted

  public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("cc");
        list.add("dd");
        list.add("aa");
        list.add("bb");
        setSorted(list);
    }
    public static void setSorted(List<String> list){
        list=list.stream().sorted().collect(Collectors.toList());
        list.forEach(System.out::println);
    }

正序

projectList = projectList.stream().sorted(Comparator.comparing(Project::getCreateTime)).collect(Collectors.toList());

按照创建时间倒序排序

projectList = projectList.stream().sorted(Comparator.comparing(Project::getCreateTime).reversed()).collect(Collectors.toList());

如果有空字符串

正序 升序

 worktimes = worktimes.stream().sorted(Comparator.comparing(l -> l.getWorkDate(), Comparator.nullsFirst(Date::compareTo))).collect(Collectors.toList());

倒序 降序

  data = data.stream().sorted(Comparator.comparing(l -> l.getUserAccount(), Comparator.nullsFirst(String::compareTo).reversed())).collect(Collectors.toList());


目录
相关文章
|
19天前
|
移动开发 前端开发 Java
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
JavaFX是Java的下一代图形用户界面工具包。JavaFX是一组图形和媒体API,我们可以用它们来创建和部署富客户端应用程序。 JavaFX允许开发人员快速构建丰富的跨平台应用程序,允许开发人员在单个编程接口中组合图形,动画和UI控件。本文详细介绍了JavaFx的常见用法,相信读完本教程你一定有所收获!
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
|
1月前
|
存储 Java 数据挖掘
Java 8 新特性之 Stream API:函数式编程风格的数据处理范式
Java 8 引入的 Stream API 提供了一种新的数据处理方式,支持函数式编程风格,能够高效、简洁地处理集合数据,实现过滤、映射、聚合等操作。
70 6
|
1月前
|
Java API 开发者
Java中的Lambda表达式与Stream API的协同作用
在本文中,我们将探讨Java 8引入的Lambda表达式和Stream API如何改变我们处理集合和数组的方式。Lambda表达式提供了一种简洁的方法来表达代码块,而Stream API则允许我们对数据流进行高级操作,如过滤、映射和归约。通过结合使用这两种技术,我们可以以声明式的方式编写更简洁、更易于理解和维护的代码。本文将介绍Lambda表达式和Stream API的基本概念,并通过示例展示它们在实际项目中的应用。
|
1月前
|
Rust 安全 Java
Java Stream 使用指南
本文介绍了Java中Stream流的使用方法,包括如何创建Stream流、中间操作(如map、filter、sorted等)和终结操作(如collect、forEach等)。此外,还讲解了并行流的概念及其可能带来的线程安全问题,并给出了示例代码。
|
2月前
|
安全 Java API
Java中的Lambda表达式与Stream API的高效结合####
探索Java编程中Lambda表达式与Stream API如何携手并进,提升数据处理效率,实现代码简洁性与功能性的双重飞跃。 ####
33 0
|
3月前
|
Java 流计算
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
57 1
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
|
3月前
|
Java Shell 流计算
Flink-02 Flink Java 3分钟上手 Stream SingleOutputStreamOpe ExecutionEnvironment DataSet FlatMapFunction
Flink-02 Flink Java 3分钟上手 Stream SingleOutputStreamOpe ExecutionEnvironment DataSet FlatMapFunction
34 1
Flink-02 Flink Java 3分钟上手 Stream SingleOutputStreamOpe ExecutionEnvironment DataSet FlatMapFunction
|
2月前
|
Java API 数据处理
探索Java中的Lambda表达式与Stream API
【10月更文挑战第22天】 在Java编程中,Lambda表达式和Stream API是两个强大的功能,它们极大地简化了代码的编写和提高了开发效率。本文将深入探讨这两个概念的基本用法、优势以及在实际项目中的应用案例,帮助读者更好地理解和运用这些现代Java特性。
|
3月前
|
存储 安全 Java
深入理解Java中的FutureTask:用法和原理
【10月更文挑战第28天】`FutureTask` 是 Java 中 `java.util.concurrent` 包下的一个类,实现了 `RunnableFuture` 接口,支持异步计算和结果获取。它可以作为 `Runnable` 被线程执行,同时通过 `Future` 接口获取计算结果。`FutureTask` 可以基于 `Callable` 或 `Runnable` 创建,常用于多线程环境中执行耗时任务,避免阻塞主线程。任务结果可通过 `get` 方法获取,支持阻塞和非阻塞方式。内部使用 AQS 实现同步机制,确保线程安全。
174 3
|
4月前
|
存储 Java API
Java——Stream流详解
Stream流是JDK 8引入的概念,用于高效处理集合或数组数据。其API支持声明式编程,操作分为中间操作和终端操作。中间操作包括过滤、映射、排序等,可链式调用;终端操作则完成数据处理,如遍历、收集等。Stream流简化了集合与数组的操作,提升了代码的简洁性
212 11