117.info
人生若只如初见

Java中stream流怎么过滤并返回对象

在Java中,可以使用Stream流来进行过滤并返回对象。以下是一个示例:

假设有一个包含Person对象的列表,我们希望根据某个条件过滤出年龄大于18岁的人。可以使用filter()方法来过滤列表,然后使用collect()方法将过滤后的结果收集到一个新的列表中。

import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;

public class Example {
    public static void main(String[] args) {
        List personList = new ArrayList<>();
        personList.add(new Person("Alice", 20));
        personList.add(new Person("Bob", 25));
        personList.add(new Person("Charlie", 17));

        List filteredList = personList.stream()
                .filter(person -> person.getAge() > 18)
                .collect(Collectors.toList());

        for (Person person : filteredList) {
            System.out.println(person.getName() + " - " + person.getAge());
        }
    }
}

class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }
}

在上面的示例中,首先创建了一个包含Person对象的列表。然后使用stream()方法将列表转换为一个流。接着使用filter()方法传入一个Lambda表达式,该表达式用来过滤出年龄大于18岁的人。最后使用collect()方法将过滤后的结果收集到一个新的列表中。

最后,使用for循环遍历新的列表,输出每个人的姓名和年龄。运行上面的代码,输出结果如下:

Alice - 20
Bob - 25

未经允许不得转载 » 本文链接:https://www.117.info/ask/fed7cAzsLAAJRBFE.html

推荐文章

  • java发送post请求报500错误怎么解决

    发送POST请求时,出现500错误通常是由于服务器内部错误导致的。要解决这个问题,可以尝试以下几个步骤: 检查请求参数:确保请求参数的格式、类型和值都正确。可...

  • java怎么调用外部接口

    在Java中,要调用外部接口,首先需要先导入该接口的包,然后通过创建该接口的实现类的对象来调用接口的方法。
    以下是一个示例代码:
    import com.examp...

  • java怎么读取并修改xml文件内容

    在Java中,可以使用javax.xml.parsers包中的DocumentBuilderFactory和DocumentBuilder类来读取和修改XML文件内容。以下是一个简单的示例代码:
    import java...

  • 怎么用java对比两个文件内容

    可以使用Java的FileInputStream和BufferedReader类来读取两个文件的内容,并进行比较。以下是一个示例代码:
    import java.io.BufferedReader;
    import ...

  • Java中stream流怎么过滤空值

    在Java中,可以使用stream流的filter()方法来过滤空值。具体的步骤如下: 首先,创建一个包含空值的stream流。
    Stream stream = Stream.of("apple", "", "b...

  • Mysql怎么将两张表的数据查出来

    要将两张表的数据查出来,可以使用MySQL的JOIN语句。JOIN语句可以通过连接两个或多个表的列,将它们的数据合并在一起。
    以下是几种常见的JOIN语句: 内连接...

  • couchbase怎么查看表索引字段

    在Couchbase中,可以使用N1QL查询语言来查看表的索引字段。以下是使用N1QL查询语句查看表的索引字段的步骤: 打开Couchbase Web控制台并登录。 选择要查看索引字...

  • oracle向上递归查询的方法是什么

    Oracle中的递归查询可以通过使用递归查询语句来实现。Oracle提供了一个特殊的关键字CONNECT BY来处理递归查询。下面是一个示例递归查询的方法: 创建一个递归查询...