Lambda表达式与Stream流 (终)

37次阅读

共计 10810 个字符,预计需要花费 28 分钟才能阅读完成。

package com.java.design.java8;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.time.*;
import java.time.format.DateTimeFormatter;
import java.time.temporal.ChronoField;
import java.util.*;
import java.util.concurrent.CompletableFuture;
import java.util.stream.Collectors;
import java.util.stream.IntStream;

/**
* @author 陈杨
*
*/

@SpringBootTest
@RunWith(SpringRunner.class)
public class LambdaInfo {
一、Lambda 表达式与 Stream 流
/*
A lambda expression can be understood as a concise representation of an anonymous function
that can be passed around: it doesn’t have a name,
but it has a list of parameters, a body, a return type,
and also possibly a list of exceptions that can be thrown.
That’s one big definition;

let’s break it down:
Anonymous:
We say anonymous because it doesn’t have an explicit name like a method would normally have: less to write and think about!
Function:
We say function because a lambda isn’t associated with a particular class like a method is.
But like a method, a lambda has a list of parameters, a body, a return type,
and a possible list of exceptions that can be thrown.
Passed around:
A lambda expression can be passed as argument to a method or stored in a variable.
Concise:
You don’t need to write a lot of boilerplate like you do for anonymous classes.

*/

/*
Stream : A sequence of elements from a source that supports data processing operations.
Sequence of elements
Source
Pipelining
Internal iteration
Traversable only once
Collections: external interation using an interator behind the scenes

*/
二、初始化测试数据
private List<Integer> list;

@Before
public void init() {

list = IntStream.rangeClosed(1, 100).boxed().collect(Collectors.toList());

list.sort(Collections.reverseOrder());
}
三、各种 API
1.allMatch
@Test

public void testLambdaInfo() {

System.out.println(“>———————Match 方法 ———————-<“);
// 一、Match 方法
// Returns whether all elements of this stream match the provided predicate.
Optional.of(list.stream().mapToInt(Integer::intValue).allMatch(i -> i > 0))
.ifPresent(System.out::println);

// Returns whether any elements of this stream match the provided predicate.
Optional.of(list.stream().mapToInt(Integer::intValue).anyMatch(i -> i > 0))
.ifPresent(System.out::println);

// Returns whether no elements of this stream match the provided predicate..
Optional.of(list.stream().mapToInt(Integer::intValue).noneMatch(i -> i > 0))
.ifPresent(System.out::println);

2、find
System.out.println(“>——————–Find 方法 ———————–<“);

// 二、Find 方法
// Returns an Optional describing the first element of this stream,
// or an empty Optional if the stream is empty.
// If the stream has no encounter order, then any element may be returned.
list.stream().mapToInt(Integer::intValue).filter(i -> i > 10).findFirst()
.ifPresent(System.out::println);

// Returns an Optional describing some element of the stream, or an empty Optional if the stream is empty.
list.stream().mapToInt(Integer::intValue).filter(i -> i > 10).findAny()
.ifPresent(System.out::println);
3、reduce
System.out.println(“>———————Reduce 方法 ———————-<“);

// 三、Reduce 方法
// Performs a reduction on the elements of this stream, using the provided identity value
// and an associative accumulation function, and returns the reduced value.

// 求和
System.out.println(list.stream().reduce(0, Integer::sum));
list.stream().mapToInt(Integer::intValue).reduce(Integer::sum)
.ifPresent(System.out::println);

// 求最大值
System.out.println(list.stream().reduce(0, Integer::max));
list.stream().mapToInt(Integer::intValue).reduce(Integer::max)
.ifPresent(System.out::println);

// 求最小值
System.out.println(list.stream().reduce(0, Integer::min));
list.stream().mapToInt(Integer::intValue).reduce(Integer::min)
.ifPresent(System.out::println);
System.out.println(“>——————————————-<“);

}
4、CompletableFuture API
@Test
public void testCompletableFuture() {

// 四、CompletableFuture API
/*
* Returns a new CompletableFuture that is asynchronously completed by a task
* running in the given executor with the value obtained by calling the given Supplier.
*/
CompletableFuture.supplyAsync(list.stream().mapToInt(Integer::intValue)::sum, System.out::println);

Optional.of(CompletableFuture.supplyAsync(list.stream().mapToInt(Integer::intValue)::sum)
.complete(55)).ifPresent(System.out::println);

// thenAccept 无返回值 Consumer<? super T> action
CompletableFuture.supplyAsync(list.stream().mapToInt(Integer::intValue)::sum)
.thenAccept(System.out::println);

// thenApply 有返回值 Function<? super T,? extends U> fn
CompletableFuture.supplyAsync(() -> list.stream().mapToInt(Integer::intValue))
.thenApply(IntStream::sum).thenAccept(System.out::println);

// 对元素及异常进行处理 BiFunction<? super T, Throwable, ? extends U> fn
CompletableFuture.supplyAsync(() -> list.stream().mapToInt(Integer::intValue))
.handle((i, throwable) -> “handle:\t” + i.sum()).thenAccept(System.out::println);

// whenCompleteAsync 完成时执行 BiConsumer<? super T, ? super Throwable> action
CompletableFuture.supplyAsync(list.stream().mapToInt(Integer::intValue)::sum)
.whenCompleteAsync((value, throwable) -> System.out.println(“whenCompleteAsync:\t” + value));

// 组合 CompletableFuture 将前一个结果作为后一个输入参数(参照 组合设计模式)
CompletableFuture.supplyAsync(() -> list.stream().mapToInt(Integer::intValue))
.thenCompose(i -> CompletableFuture.supplyAsync(i::sum)).thenAccept(System.out::println);

// 合并 CompletableFuture
CompletableFuture.supplyAsync(list.stream().mapToInt(Integer::intValue)::sum)
.thenCombine(CompletableFuture.supplyAsync(() -> list.stream()
.mapToDouble(Double::valueOf).sum()), Double::sum).thenAccept(System.out::println);

// 合并 CompletableFuture
CompletableFuture.supplyAsync(list.stream().mapToInt(Integer::intValue)::sum)
.thenAcceptBoth(CompletableFuture.supplyAsync(list.stream()
.mapToDouble(Double::valueOf)::sum),
(r1, r2) -> System.out.println(“thenAcceptBoth:\t” + r1 + “\t” + r2));

// 2 个 CompletableFuture 运行完毕后运行 Runnable
CompletableFuture.supplyAsync(() -> {
System.out.println(Thread.currentThread().getName() + “\tis running”);
return list.stream().mapToInt(Integer::intValue).sum();
})
.runAfterBoth(
CompletableFuture.supplyAsync(() -> {
System.out.println(Thread.currentThread().getName() + “\tis running”);
return list.stream().mapToDouble(Double::valueOf).sum();
}),
() -> System.out.println(“The 2 method have done”));

// 2 个 CompletableFuture 有一个运行完就执行 Runnable
CompletableFuture.supplyAsync(() -> {
System.out.println(Thread.currentThread().getName() + “\tis running”);
return list.stream().mapToInt(Integer::intValue).sum();
})
.runAfterEither(
CompletableFuture.supplyAsync(() -> {
System.out.println(Thread.currentThread().getName() + “\tis running”);
return list.stream().mapToDouble(Double::valueOf).sum();
}),
() -> System.out.println(“The 2 method have done”));

// 2 个 CompletableFuture 有一个运行完就执行 Function<? super T, U> fn
CompletableFuture.supplyAsync(
list.stream().mapToInt(Integer::intValue).max()::getAsInt)
.applyToEither(
CompletableFuture.supplyAsync(list.stream().mapToInt(Integer::intValue).min()::getAsInt)
, v -> v * 10)
.thenAccept(System.out::println);

// 2 个 CompletableFuture 有一个运行完就执行 Consumer<? super T> action
CompletableFuture.supplyAsync(
list.stream().mapToInt(Integer::intValue).max()::getAsInt)
.acceptEither(
CompletableFuture.supplyAsync(list.stream().mapToInt(Integer::intValue).min()::getAsInt)
, System.out::println);

// 将集合中每一个元素都映射成为 CompletableFuture<Integer> 对象
List<CompletableFuture<Integer>> collect =
list.stream().map(i -> CompletableFuture.supplyAsync(i::intValue))
.collect(ArrayList::new, ArrayList::add, ArrayList::addAll);
// 集合转数组
CompletableFuture[] completableFutures = collect.toArray(CompletableFuture[]::new);

// 有一个 task 执行完毕
CompletableFuture.anyOf(completableFutures)
.thenRun(() -> System.out.println(“ 有一个 task 执行完毕 —>first done”));
// 有且仅有所有 task 执行完毕
CompletableFuture.allOf(completableFutures)
.thenRun(() -> System.out.println(“ 有且仅有所有 task 执行完毕 —>done”));

}
5、Java.time API
@Test
public void testLocalDateTime() {

// 五、Java.time API
LocalDate localDate = LocalDate.of(2019, 12, 1);

// 当前时间
Optional.of(LocalDate.now()).ifPresent(System.out::println);

// 年份
Optional.of(localDate.getYear()).ifPresent(System.out::println);
OptionalInt.of(localDate.get(ChronoField.YEAR)).ifPresent(System.out::println);

// 月份 (Jan–>Dec)
Optional.of(localDate.getMonth()).ifPresent(System.out::println);

// 月份 (1–>12)
Optional.of(localDate.getMonthValue()).ifPresent(System.out::println);
OptionalInt.of(localDate.get(ChronoField.MONTH_OF_YEAR)).ifPresent(System.out::println);

// 年中的第几天
Optional.of(localDate.getDayOfYear()).ifPresent(System.out::println);
OptionalInt.of(localDate.get(ChronoField.DAY_OF_YEAR)).ifPresent(System.out::println);

// 月中的第几天
Optional.of(localDate.getDayOfMonth()).ifPresent(System.out::println);
OptionalInt.of(localDate.get(ChronoField.DAY_OF_MONTH)).ifPresent(System.out::println);

// 星期几 (Mon–>Sun)
Optional.of(localDate.getDayOfWeek()).ifPresent(System.out::println);

// 星期几 (1–>7)
OptionalInt.of(localDate.get(ChronoField.DAY_OF_WEEK)).ifPresent(System.out::println);

// 时代(公元前、后)CE BCE
Optional.of(localDate.getEra()).ifPresent(System.out::println);

// 时代(公元前、后)1—>CE 0—>BCE
Optional.of(localDate.getEra().getValue()).ifPresent(System.out::println);
OptionalInt.of(localDate.get(ChronoField.ERA)).ifPresent(System.out::println);

// ISO 年表
Optional.of(localDate.getChronology().getId()).ifPresent(System.out::println);

// 当前时间
LocalTime time = LocalTime.now();

// 时
OptionalInt.of(time.getHour()).ifPresent(System.out::println);
OptionalInt.of(time.get(ChronoField.HOUR_OF_DAY)).ifPresent(System.out::println);

// 分
OptionalInt.of(time.getMinute()).ifPresent(System.out::println);
OptionalInt.of(time.get(ChronoField.MINUTE_OF_DAY)).ifPresent(System.out::println);

// 秒
OptionalInt.of(time.getSecond()).ifPresent(System.out::println);
OptionalInt.of(time.get(ChronoField.SECOND_OF_DAY)).ifPresent(System.out::println);

// 纳秒
OptionalInt.of(time.getNano()).ifPresent(System.out::println);
OptionalLong.of(time.getLong(ChronoField.NANO_OF_SECOND)).ifPresent(System.out::println);

// 中午时间
Optional.of(LocalTime.NOON).ifPresent(System.out::println);

// 午夜时间
Optional.of(LocalTime.MIDNIGHT).ifPresent(System.out::println);

// 自定义格式化时间
DateTimeFormatter customDateTimeFormatter = DateTimeFormatter.ofPattern(“yyyy-MM-dd HH:mm:ss E”);
LocalDateTime localDateTime = LocalDateTime.of(localDate, time);
Optional.of(localDateTime.format(customDateTimeFormatter)).ifPresent(System.out::println);

// 根据传入的文本匹配自定义指定格式进行解析
Optional.of(LocalDateTime.parse(“2019-12-25 12:30:00 周三 ”, customDateTimeFormatter))
.ifPresent(System.out::println);

// 时间点 Instant
Instant start = Instant.now();
try {
Thread.sleep(10_000);
} catch (InterruptedException e) {
e.printStackTrace();
}
Instant end = Instant.now();

// Duration 时间段
Duration duration = Duration.between(start, end);
OptionalLong.of(duration.toNanos()).ifPresent(System.out::println);

// Period 时间段
Period period = Period.between(LocalDate.now(), localDate);

OptionalInt.of(period.getYears()).ifPresent(System.out::println);
OptionalInt.of(period.getMonths()).ifPresent(System.out::println);
OptionalInt.of(period.getDays()).ifPresent(System.out::println);

// The Difference Between Duration And Period
// Durations and periods differ in their treatment of daylight savings time when added to ZonedDateTime.
// A Duration will add an exact number of seconds, thus a duration of one day is always exactly 24 hours.
// By contrast, a Period will add a conceptual day, trying to maintain the local time.

}

}

正文完
 0