JDK1.8 新特性之Stream的常用方法2

终止操作常用方法:

    查找与匹配

        allMatch --- 检查是否匹配所有元素

        anyMatch --- 检查是否至少匹配一个元素

        noneMatch --- 检查是否没有匹配所有元素

        findFirst --- 返回第一个元素

        findAny  --- 返回当前流中的任意元素

        count  --- 返回流中元素的总个数

        max  --- 返回流中最大值

        min  --- 返回流中最小值

    peek: 返回由该流的元素组成的流,并在所提供的流中执行所提供的每个元素上的动作

    规约: reduce(T identity, BinaryOperator) --- 可以将流中元素反复结合起来,得到一个值

    收集:  collect --- 将流转换为其他形式. 接收一个Collection接口的实现, 用于给Stream中元素做汇总的方法

    分组: emps.stream().collect(Collectors.groupingBy(Employee::getStatus))

    分区: emps.stream().collect(Collectors.partitioningBy

 

基础员工类:点我

 

测试用例:

import com.sarj.streetlamp.optional.Employee;
import org.junit.Test;

import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.Stream;

/**
 * 终止操作常用方法:
    查找与匹配
        allMatch --- 检查是否匹配所有元素
        anyMatch --- 检查是否至少匹配一个元素
        noneMatch --- 检查是否没有匹配所有元素
        findFirst --- 返回第一个元素
        findAny  --- 返回当前流中的任意元素
        count  --- 返回流中元素的总个数
        max  --- 返回流中最大值
        min  --- 返回流中最小值
    peek: 返回由该流的元素组成的流,并在所提供的流中执行所提供的每个元素上的动作
    规约: reduce(T identity, BinaryOperator) --- 可以将流中元素反复结合起来,得到一个值
JDK 1.8有多个常用新特性,以下是一些介绍: - **Lambda表达式**:这是JDK 1.8的重要特性之一,结合函数式编程,可简化代码,减少样板代码的编写。例如在使用线程时,传统写法是创建一个`Runnable`的匿名内部类,而使用Lambda表达式则可以让代码更加简洁,示例如下: ```java // 传统写法 new Thread(new Runnable() { @Override public void run() { System.out.println("Hello"); } }).start(); // Lambda表达式写法 new Thread(() -> System.out.println("Hello")).start(); ``` - **函数式接口**:函数式接口是只包含一个抽象方法的接口,它是Lambda表达式的基础。Java 8在`java.util.function`包中提供了许多常用的函数式接口,如`Predicate`、`Consumer`、`Function`等,方便进行函数式编程。 - **方法引用**:方法引用提供了一种更简洁的方式来调用已存在的方法。例如可以通过`System.out::println`来引用`System.out`对象的`println`方法,示例如下: ```java import java.util.Arrays; import java.util.List; public class MethodReferenceExample { public static void main(String[] args) { List<String> names = Arrays.asList("Alice", "Bob", "Charlie"); names.forEach(System.out::println); } } ``` - **Stream API**:提供了一种声明式的数据处理方式,允许以更简洁、高效的方式操作集合。它具有声明式编程、惰性求值、链式调用、并行处理等特点。例如对集合进行过滤和输出: ```java import java.util.Arrays; import java.util.List; public class StreamExample { public static void main(String[] args) { List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5); numbers.stream() .filter(n -> n % 2 == 0) .forEach(System.out::println); } } ``` - **日期时间组件**:引入了新的日期时间API,如`LocalDate`、`LocalTime`、`LocalDateTime`、`Instant`、`DateTimeFormatter`等,这些类提供了更简洁、更安全的日期和时间处理方式,解决了旧的`Date`和`Calendar`类存在的线程安全等问题。示例如下: ```java import java.time.LocalDate; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; public class DateTimeExample { public static void main(String[] args) { LocalDate currentDate = LocalDate.now(); System.out.println("Current Date: " + currentDate); LocalDateTime currentDateTime = LocalDateTime.now(); DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); String formattedDateTime = currentDateTime.format(formatter); System.out.println("Formatted DateTime: " + formattedDateTime); } } ``` - **接口的默认方法和静态方法**:传统上,接口主要包含方法签名,不涉及具体实现细节。从Java 8开始,接口引入了默认方法和静态方法,增强了接口的灵活性和功能性。默认方法使用`default`关键字定义,允许接口有具体的方法实现;静态方法使用`static`关键字定义,可直接通过接口名调用。示例如下: ```java interface MyInterface { default void defaultMethod() { System.out.println("This is a default method."); } static void staticMethod() { System.out.println("This is a static method."); } } class MyClass implements MyInterface { // 可以不实现默认方法,因为接口已经提供了实现 } public class InterfaceExample { public static void main(String[] args) { MyClass myClass = new MyClass(); myClass.defaultMethod(); MyInterface.staticMethod(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值