1. Lambda表达式

Lamba 表达式对于曾经应用了其余的应用过流式编程语言的来说,可能并不生疏,Lambda 表达式(或函数)只是一个匿名函数,即没有名称且没有绑定标识符的函数。它们齐全写在须要的中央,通常作为其余函数的参数

lambda 表达式的根本语法:

parameters 参数expression 表达式(办法)(parameters) -> expressionor(parameters) -> { statements; }or () -> expression

典型的lambda 表达式 实例如下所示

(x, y) -> x + y  

编写 lambda 表达式的规定

  1. 一个lambda 表达式能够有零个,一个或者是多个参数
  2. 参数的类型能够显示的申明,也能够从上下文中推断进去
  3. 多个参数用强制括号括起来并用逗号分隔,空括号用于示意一组空参数
  4. 当有单个参数时,如果推断其类型,则不强制应用括号,
  5. lambda 表达式的主体能够是零个,一个或者是多个
  6. 如果lambda 表达式的主题有单个语句,则大括号不是必须的,并且匿名函数的返回类型与主体表达式返回类型雷同,当注释中有多个执行语句的时候,必须将这些语句用大括号括起来

2 性能接口(functionInterface)

性能接口越是成为繁多形象办法接口,它们只容许在它们外部应用一种形象办法,java8中引入一个注解 @functionInterface,当 你注解的接口守法了函数式接口的规定的时候,编译的时候就会报错.

实例

@FunctionalInterfacepublic interface MyFirstFunctionalInterface {    public void firstWork();}

留神的是 注解@FunctionalInterface 如果被省略,性能接口同样是无效的,它仅仅用于告诉编译器在接口内强制执行单个形象办法,因为默认办法不是形象的,所以 能够随便将默认办法退出到你的性能接口中.

另一个要记住的重要的一点是,如果接口申明了一个笼罩的公共办法之一的形象办法,java.lang.Object, 这个也不会计入形象办法计数,因为接口的任何实现都将有来自java.lang.Object或其余中央的实现。例如,上面是齐全无效的性能接口。

@FunctionalInterfacepublic interface MyFirstFunctionalInterface {    public void firstWork();     @Override    public String toString();                //重写Object 中的办法,不参加计数     @Override    public boolean equals(Object obj);        //重写Object 中的办法,不参加计数}

3. 默认办法

java8 中容许你在接口中增加非形象办法, 然而这些办法必须申明为默认办法,默认办法,java8 中引入了默认办法启用lambda 表达式的性能

例子

public interface Moveable {    default void move(){        System.out.println("I am moving");    }

Moveable 接口定义了 一个办法 move 并提供了一个默认实现, 如果任何的类实现了这个接口,那么能够不须要实现这个接口的move 办法版本,能够间接调用

例如

public class Animal implements Moveable{    public static void main(String[] args){        Animal tiger = new Animal();        tiger.move();    }}  Output: I am moving

当然如果本人违心本人 自定义move办法,那么能够提供本人自定义实现并笼罩办法.

4 . Java8 流

Stream 是 java 8 中最大的改变,提供了一个流式解决数据的形式,包含过滤,转换或任何其余可能对应用程序有用的形式,java8 中的Stream API 反对不同类型的迭代, 上面是一个steam Api 实例

List<String> items;String prefix;List<String> filteredList = items.stream().filter(e ->(!e.startsWith(prefix))).collect(Collectors.toList());

这里的items.stream 就是咱们本人心愿items 应用Stream API 解决汇合的数据

5. 日期/工夫 api的更改

Date 类型的日期人曾经过期了,能够应用 LocalDate,LocalTimelocalDateTime

  • LocalDate类代表一个日期。没有工夫或时区的示意。
  • LocalTime级示意工夫。没有日期或时区的示意。
  • LocalDateTime类代表一个日期-工夫。没有时区的示意

如果想将 工夫和 时区一期应用话,Lambda 表达式提供了额定的三个相似下面的类, OffsetDate,OffsetTimeOffsetDateTime,时区的便宜能够应用 "+8" 或者是 "Europe/Paris" 格局的,

LocalDate localDate = LocalDate.now();LocalTime localTime = LocalTime.of(12, 20);LocalDateTime localDateTime = LocalDateTime.now(); OffsetDateTime offsetDateTime = OffsetDateTime.now();ZonedDateTime zonedDateTime = ZonedDateTime.now(ZoneId.of("Europe/Paris"));
工夫戳和持续时间

为了示意任何时刻的特定工夫戳,须要应用Instant, Instant 类示意工夫纳秒 的精度霎时,对 Instant 的操作包含与另一个比拟Instant以及增加或减去持续时间。

Instant instant = Instant.now();Instant instant1 = instant.plus(Duration.ofMillis(5000));Instant instant2 = instant.minus(Duration.ofMillis(5000));Instant instant3 = instant.minusSeconds(10);

Duration 是java 8 中首次引入的权限概念,示意两个工夫戳之间的时间差.

Duration duration = Duration.ofMillis(5000);duration = Duration.ofSeconds(60);duration = Duration.ofMinutes(10);

Duration 解决小的工夫,例如毫秒,秒,分和工夫, 如果想获取更长时间的继续,那么须要应用 Period 这个类

Period period = Period.ofDays(6);period = Period.ofMonths(6);period = Period.between(LocalDate.now(), LocalDate.now().plusDays(60));