Java 8 新特性
Java 8 (又称为 jdk 1.8) 是 Java 语言开发的一个主要版本。
新特性
Java8 新增了非常多的特性,我们主要讨论以下几个:
l Lambda 表达式 − Lambda允许把函数作为一个方法的参数
l 方法引用 − 方法引用提供了非常有用的语法,可以直接引用已有Java类或对象(实例)的方法或构造器。与lambda联合使用,方法引用可以使语言的构造更紧凑简洁,减少冗余代码。
l 默认方法 − 默认方法就是一个在接口里面有了一个实现的方法。
l 新工具 − 新的编译工具,如:Nashorn引擎 jjs、 类依赖分析器jdeps。
l Stream API −新添加的Stream API(java.util.stream) 把真正的函数式编程风格引入到Java中。
l Date Time API − 加强对日期与时间的处理。
l Optional 类 − Optional 类已经成为 Java 8 类库的一部分,用来解决空指针异常。
l Nashorn, JavaScript 引擎 − Java 8提供了一个新的Nashorn javascript引擎,它允许我们在JVM上运行特定的javascript应用。
Java 8 Lambda 表达式
Lambda 表达式,也可称为闭包,它是推动 Java 8 发布的最重要新特性。
Lambda 允许把函数作为一个方法的参数(函数作为参数传递进方法中)。
使用 Lambda 表达式可以使代码变的更加简洁紧凑。
以下是lambda表达式的重要特征:
· 可选类型声明:不需要声明参数类型,编译器可以统一识别参数值。
· 可选的参数圆括号:一个参数无需定义圆括号,但多个参数需要定义圆括号。
· 可选的大括号:如果主体包含了一个语句,就不需要使用大括号。
· 可选的返回关键字:如果主体只有一个表达式返回值则编译器会自动返回值,大括号需要指定明表达式返回了一个数值。
Java 8 方法引用
方法引用通过方法的名字来指向一个方法。
方法引用可以使语言的构造更紧凑简洁,减少冗余代码。
方法引用使用一对冒号(::)。
l 静态方法引用:它的语法是Class::static_method
l 特定类的任意对象的方法引用:它的语法是Class::method
l 特定对象的方法引用:它的语法是instance::method
l 构造器引用:它的语法是Class::new,或者更一般的Class< T >::new
Java 8 Stream
Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据。
Stream 使用一种类似用 SQL 语句从数据库查询数据的直观方式来提供一种对 Java 集合运算和表达的高阶抽象。
Stream API可以极大提供Java程序员的生产力,让程序员写出高效率、干净、简洁的代码。
这种风格将要处理的元素集合看作一种流, 流在管道中传输, 并且可以在管道的节点上进行处理, 比如筛选, 排序,聚合等。
元素流在管道中经过中间操作(intermediate operation)的处理,最后由最终操作(terminal operation)得到前面处理的结果。
什么是 Stream?
Stream(流)是一个来自数据源的元素队列并支持聚合操作
Java 8 Optional 类
Optional 类是一个可以为null的容器对象。如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象。
Optional 是个容器:它可以保存类型T的值,或者仅仅保存null。Optional提供很多有用的方法,这样我们就不用显式进行空值检测。
Optional 类的引入很好的解决空指针异常。
下面是我整理的自己常用到java8代码块,与大家分享一下:
//count
long count=words.stream().filter(w->w.length()>2).count();
//分区
Map<Boolean, List<BillGroupingDto>> parts = finalDiff.stream().collect(Collectors.partitioningBy(x -> productTypeIds.contains(x.getProductTypeId())));
//截取条数
Stream<Double> randoms=Stream.generate(Math::random).limit(20);
randoms.forEach(System.out::println);
//返回类型值
List<Integer> userIds = users.stream().map(f -> { return f.getId(); }).collect(Collectors.toList());
userIds.forEach(System.out::println);
//排序
List<String> words = Arrays.asList("asdasd", "hgjgh", "cvbvn", "ewrwer", "asdasdasd", "e", "wer", "asdasdasd");
words=words.stream().sorted(Comparator.comparing(String::length)).collect(Collectors.toList());
words.forEach(System.out::println);
//排序:
productSubTypeDtos = productSubTypeDtos
.stream()
.sorted(Comparator.comparing(ProductSubTypeDto::getProductType)
.collect(Collectors.toList());
//两次排序:
List<ChargeRuleLogRs>sortedTotalChargeRuleLogRses=
totalChargeRuleLogRses
.stream()
.sorted(Comparator.comparingInt(ChargeRuleLogRs::getMonth)
.reversed().thenComparing(
Comparator.comparingLong(ChargeRuleLogRs::getVer)
.reversed()))
.collect(Collectors.toList());
//过滤:
List<ChargeRuleLog> filteredChargeRuleLogs =
chargeRuleLogs.stream()
.filter(b -> b.getProductTypeCode().toUpperCase()
.contains(productType.toUpperCase()))
.collect(Collectors.toList());
final Collection< String > result = tasks
.stream() // Stream< String >
.mapToInt( Task::getPoints ) // IntStream
.asLongStream() // LongStream
.mapToDouble( points -> points / totalPoints ) // DoubleStream
.boxed() // Stream< Double >
.mapToLong( weigth -> ( long )( weigth * 100 ) ) // LongStream
.mapToObj( percentage -> percentage + "%" ) // Stream< String>
.collect( Collectors.toList() );