1. Lambda表达式
Lamba 表达式对于曾经应用了其余的应用过流式编程语言的来说,可能并不生疏,Lambda 表达式(或函数)只是一个匿名函数,即没有名称且没有绑定标识符的函数。它们齐全写在须要的中央,通常作为其余函数的参数。
lambda 表达式的根本语法:
parameters 参数expression 表达式(办法)(parameters) -> expressionor(parameters) -> { statements; }or () -> expression
典型的lambda 表达式 实例如下所示
(x, y) -> x + y
编写 lambda 表达式的规定
- 一个lambda 表达式能够有零个,一个或者是多个参数
- 参数的类型能够显示的申明,也能够从上下文中推断进去
- 多个参数用强制括号括起来并用逗号分隔,空括号用于示意一组空参数
- 当有单个参数时,如果推断其类型,则不强制应用括号,
- lambda 表达式的主体能够是零个,一个或者是多个
- 如果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
,LocalTime
和 localDateTime
- 本
LocalDate
类代表一个日期。没有工夫或时区的示意。 - 该
LocalTime
级示意工夫。没有日期或时区的示意。 - 本
LocalDateTime
类代表一个日期-工夫。没有时区的示意
如果想将 工夫和 时区一期应用话,Lambda 表达式提供了额定的三个相似下面的类, OffsetDate
,OffsetTime
和OffsetDateTime
,时区的便宜能够应用 "+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));