java8 语法

// 1. Lambda 表达式 java.util.function.*
{
// 提供者
Supplier supplier = () -> 5;
// 消费者
Consumer consumer = (Integer a) -> System.out.println(a);
// 消费者(缩写)
Consumer consumer2 = a -> System.out.println(a);
// 二元消费者
BiConsumer<Integer, Integer> biConsumer = (a, b) -> System.out.println(a + b);
// 函数 接收一个参数,返回一个结果
Function<Integer, Integer> function = a -> a + 1;
// 二元函数 接收两个参数,返回一个结果
BiFunction<Integer, Integer, Integer> biFunction = (a, b) -> a + b;
// 二元操作 接收两个同类型的参数,返回一个同类型结果 继承BiFunction
BinaryOperator binaryOperator = (a, b) -> a + b;
// 接收一个参数,返回一个boolean类型的结果
Predicate predicate = a -> a > 5;

    // 如果一个接口只有一个方法 就可以使用Lambda表达式代表这个接口的一个实例 如 Runnable Comparator
    new Thread(() -> {});
}

// 2. 函数引用
{
    // 方法引用
    List<String> list = Arrays.asList("1", "2", "3");
    list.forEach(System.out::println);
    // 构造器引用
    Supplier<Stu> supplier = Stu::new;
}

// 3. Stream 流式接口
{
    Stu stu1 = new Stu(1, "stu1", 1, Boolean.TRUE);
    Stu stu2 = new Stu(3, "stu2", 2, Boolean.FALSE);
    Stu stu3 = new Stu(2, "stu3", 1, Boolean.TRUE);
    Stu stu4 = new Stu(4, "stu4", 2, Boolean.FALSE);
    List<Stu> stus = Arrays.asList(stu1, stu2, stu3, stu4);

    // id正序 等价于stus.sort((o1, o2) -> o1.getId().compareTo(o2.getId()));
    stus.sort(Comparator.comparing(Stu::getId));
    // id倒序
    stus.sort((o1, o2) -> o2.getId().compareTo(o1.getId()));
    // 特殊排序 flag为ture排在前面
    stus.sort((o1, o2) -> o2.getFlag() ? 1 : -1);

    // 提取id 获得id集合
    stus.stream().map(Stu::getId).collect(Collectors.toList());
    // 过滤 获得flag为ture的Stu
    stus.stream().filter(Stu::getFlag).collect(Collectors.toList());
    // 过滤 获得flag为false的Stu
    stus.stream().filter(o -> !o.getFlag()).collect(Collectors.toList());

    // list转map key为id value为Stu
    // Function.identity() 等效 a -> a 返回对象本身
    Map<Integer, Stu> stuMap = stus.stream().collect(Collectors.toMap(Stu::getId, Function.identity()));

    // 根据性别分组
    Map<Integer, List<Stu>> stuMap2 = stus.stream().collect(Collectors.groupingBy(Stu::getSex));

    // 合并姓名 以逗号分割
    stus.stream().map(Stu::getName).collect(Collectors.joining(","));

    // 取id最大值
    OptionalInt max = stus.stream().mapToInt(Stu::getId).max();
    // Optional 参见https://www.cnblogs.com/KingKirito1024/p/10346690.html
    // max.isPresent() ? max.getAsInt() : 0;
    max.orElse(0);

}

// CompletableFuture 多线程
{
    List<Integer> list = Arrays.asList(1, 2, 3, 4);
    // 异步执行 使用的是默认的ForkJoinPool
    list.forEach(o -> CompletableFuture.runAsync(() -> System.out.println(Thread.currentThread().getName() + "------" + o * 2)));
    ExecutorService executorService = Executors.newFixedThreadPool(4);
    // 使用自己定义的线程池
    list.forEach(o -> CompletableFuture.runAsync(() -> System.out.println(Thread.currentThread().getName() + "------" + o * 2), executorService));

    List<Integer> result = new ArrayList<>();
    CompletableFuture[] completableFutures = list.stream().map(o -> CompletableFuture.supplyAsync(() -> o + 1)

// .thenApply(t -> t + 2) // 可以不要
.whenComplete((r, e) -> {
if (e != null) {
System.out.println(e.getMessage());
}else {
result.add®;
}
})
).toArray(CompletableFuture[]::new);
// join会阻塞主线程,等待所以任务线程执行完成
CompletableFuture.allOf(completableFutures).join();
result.forEach(System.out::println);
}

// 时间类
{
    // Instant
    Instant.now(); // 获取当前时间戳
    // LocalDate
    LocalDate.now(); // 2019-02-13
    // LocalTime
    LocalTime.now(); // 18:19:15
    // LocalDateTime
    LocalDateTime.now(); // 2019-02-13 18:19:15
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 8 中,可以使用 lambda 表达式来处理异常。具体的语法如下: ```java try { // 可能会抛出异常的代码 } catch(ExceptionType1 | ExceptionType2 | ... | ExceptionTypeN e) { // 处理异常的代码 } ``` 其中,竖线 `|` 表示逻辑或运算符,可以同时捕捉多个异常类型。使用这种语法时,异常类型必须是同一级别的,即它们必须继承自同一个父类或实现同一个接口。 例如,下面的代码使用 lambda 表达式来捕捉 `IOException` 和 `NullPointerException` 异常: ```java try { // 可能会抛出异常的代码 } catch(IOException | NullPointerException e) { // 处理异常的代码 } ``` 注意,在使用 lambda 表达式捕捉异常时,异常参数必须放在 lambda 表达式的参数列表中,并且在参数列表中只能有一个异常参数。例如: ```java try { // 可能会抛出异常的代码 } catch(Exception e) { handleException((ex) -> { // 处理异常的代码 }, e); } private static <T extends Exception> void handleException(ExceptionConsumer<T> consumer, T exception) throws T { consumer.accept(exception); } @FunctionalInterface private interface ExceptionConsumer<T extends Exception> { void accept(T exception) throws T; } ``` 上面的代码中,`handleException` 方法使用泛型来捕捉任意类型的异常,并将异常传递给 lambda 表达式中的 `ExceptionConsumer` 接口的 `accept` 方法进行处理。同时,lambda 表达式中只有一个异常参数 `ex`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值