一、支持 lambda 表达式

例如:查询学生信息,并打印

 List<Student> studentList = Student.findAllStudent();
for(Student student:studentList){
System.out.println(student);
}

使用 Lambda 的写法

 Student.findAllStudent().stream().forEach(e->System.out.println(e));
 Student.findAllStudent().forEach(e->System.out.println(e));

例如:创建一个线程

  Runnable runnable = new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName()+":重写run 方法");
}
}; Thread t1 = new Thread(runnable,"t1");
t1.start();

使用 Lambda 的写法:

new Thread(()->System.out.println(Thread.currentThread().getName()+":重写run 方法"),"t2").start();

使用 Lambda 的前提:必须满足是函数式接口,Runnable 就是一个函数式接口,用@FunctionalInterface 申明

此外: Java8 提供了模板函数式的接口在包: Java.util.function

01. 消费者接口

 02.函数接口

03.判断接口

04.提供者接口

除了上述接口,Java 就有的函数式接口Runnabkle Callable Comparator

Lambda中使用的变量必须显示的声明为 final

方法引用:

Student.findAllStudent().stream().forEach(System.out::println);

例如:

(Student s)->s.getSex();

Student::getSex

例如:输出所有学生的姓名

Student.findAllStudent().stream().map(Student::getName).forEach(System.out::println);

 复合函数:

Function<Integer,Integer> f = x->x+4;
Function<Integer,Integer> g = x->x*2;
Function<Integer,Integer> k = f.andThen(g);
System.out.println(k.apply(2));

解析:先将输入 +4 ,将得到的结果 *2 ,组合使用函数

二、引入流

流在 java.util.stream.Stream,支持数据处理操作的源生成的元素序列。

filter :接收Lambda,从流中排除某些元素

map: 接受一个lambda,将元素转换成其他形式或者提取信息

limit: 截断流,使元素不超过指定数量

collect: 将流转换为其他形式

 例如:查询并打印年龄大于20的学生信息

 List<Student> students = Student.findAllStudent();
List<Student> res = new ArrayList<>();
for(Student student :students){
if(student.getAge()>20){
res.add(student);
}
}
for(Student student: res){
System.out.println(student);
}

使用流:

  Student.findAllStudent().stream()
.filter(e->e.getAge()>20)
.forEach(System.out::println);

 例如:查询所有北京的学生,并按年龄升序输出

  Student.findAllStudent().stream()
.filter(e->e.getAddress().equals("北京"))
.sorted(Comparator.comparing(Student::getAge))
.forEach(System.out::println);

内部迭代与外部迭代:

for-each 结构是一个语法糖,背后的是 Iterator 还丑陋的东西。

流可以分为:中间操作、终端操作

中间操作: filter 、 sorted 等会返回另一个流。{filter、map、limit、sorted、distinct}

终端操作:终端操作会从流的流水线生成结果,结果不是流的值。 void 、list 等结果.{forEach、count、collect}

 例如:查询集合中的偶数,去重复

 List<Integer> numbers = Arrays.asList(10,12,2,12,10,1,2);

      numbers.stream()
.filter(e->e%2==0)
.distinct()
.forEach(System.out::println);

例如:查询集合中前 3 个数据

numbers.stream()
.limit(3)
.forEach(System.out::println);

例如:忽略集合中前3个数据

numbers.stream()
.skip(3)
.forEach(System.out::println);

例如:查询学生信息中地址,去重

 Student.findAllStudent().stream()
.map(e->e.getAddress())
.distinct()
.forEach(System.out::println);

 例如:将【“Hello”,“World”】 处理为:【“H”,"e","l","o"...】

 List<String> str = Arrays.asList("Hello","World");
List<String[]> res = str.stream()
.map(e->e.split(""))
.distinct()
.collect(toList());

返回的是2个String 数组,而想要的结果是一个string 数组

 List<String> res = str.stream()
.map(e->e.split(""))
.flatMap(Arrays::stream)
.distinct()
.collect(toList());
System.out.println(res);

flatMap : 把流中的每个值都换成另一个流,然后把所有的流连接起来形成一个流。

例如:判断学生中是否所有的年龄都小于20

   boolean res =Student.findAllStudent().stream()
.allMatch(e->e.getAge()<20);
System.out.println(res);

例如:判断学生中是否有成都的

 boolean res =Student.findAllStudent().stream()
.anyMatch(e->e.getAddress()=="成都");
System.out.println(res);

规约:求学生的年龄和

int sum = Student.findAllStudent().stream()
.map(Student::getAge)
.reduce(0,(e1,e2)->e1+e2);
System.out.println(sum);
 int sum = Student.findAllStudent().stream()
.map(Student::getAge)
.reduce(0,Integer::sum);
System.out.println(sum);

无初始值-规约:

  Optional<Integer> sum = Student.findAllStudent().stream()
.map(Student::getAge)
.reduce((e1,e2)->e1+e2);
System.out.println(sum);

例如:返回所有学生姓名字符串,按字母顺序排列

 String str = Student.findAllStudent().stream()
.map(Student::getName)
.distinct()
.sorted()
.reduce("",(e1,e2)->e1+e2);
System.out.println(str);

例如:查找年龄最小的学习年龄

 Optional<Integer> min = Student.findAllStudent().stream()
.map(Student::getAge)
.reduce(Integer::min);
System.out.println(min);

使用 groupingBy 按城市分组查询:

Map<String,List<Student>> map = Student.findAllStudent().stream()
.collect(groupingBy(Student::getAddress)); for(Map.Entry<String,List<Student>> entry: map.entrySet()){
System.out.println(entry.getKey()+","+entry.getValue());
}

 收集器的 Joining 汇总

joining 会把流中每一个对象应用 toString 方法得到的字符串连接成一个字符串。

例如:将城市去重以字符串返回

  String str = Student.findAllStudent().stream()
.map(Student::getAddress)
.distinct()
.collect(joining());
System.out.println(str);

 String str = Student.findAllStudent().stream()
.map(Student::getAddress)
.distinct()
.collect(joining(","));
System.out.println(str);

 例如:将学生按年龄分组

 Map<Integer,List<Student>> map = Student.findAllStudent().stream()
.collect(groupingBy(Student::getAge)); for(Map.Entry<Integer,List<Student>> entry:map.entrySet()){
System.out.println(entry.getKey()+","+entry.getValue());
}

 使用 counting 

计算每个年龄组人的个数

Map<Integer,Long> map = Student.findAllStudent().stream()
.collect(groupingBy(Student::getAge,counting())); for(Map.Entry<Integer,Long> entry:map.entrySet()){
System.out.println(entry.getKey()+","+entry.getValue());
}

并行流

使用 parallelStream 方法把集合转换为并行流

打印学生信息

 Student.findAllStudent().parallelStream().forEach(System.out::println);

输出学生姓名

 String str = Student.findAllStudent().parallelStream()
.map(Student::getName)
.collect(joining(","));
System.out.println(str);

分支/合并框架(ForkJoinPool)

目的:以递归方式将可以并行的任务拆分成更小的任务,然后将每个子任务的结果合并起来生成整体的结果

继承 RecursiveTask<T>

Spliterator : 可分迭代器,可并行遍历数据源中的数据

三、默认方法

问题:接口中的方法,子类必须实现。由于 java8 接口增加许多,为了不带来更多的问题,添加新的机制

1.java8 允许在接口内声明静态方法

2.java8 引入一个新的功能 ,默认方法。接口能够提供具体的实现

四、Optional 取代 null

java.util.Optional<T>

当变量存在时,Optional 对对象简单的封装,当变量不存在时,缺失的值被建模成 kong  的optional 对象。由 Optional.empty() 返回

五、CompleteableFuture 组合式异步编程

Future 接口,java5引入。提供了异步操作。

六、新的日期与时间 API

java.util.Date 、 java.utlo.Calender 设计的缺陷

缺陷: java.util.Date  无法表示日期,只能以毫秒精确时间。年份的起始选择的是 1900 年,月份从 0 开始。

缺陷:java.util.Calendar 月份呢依然是从 0开始,取消 1900 年开始。

新的时间: java.time 包

1.获取当前日期

 LocalDate today = LocalDate.now();
System.out.println(today);

 2.获取指定日期

 LocalDate localDate = LocalDate.of(2018,4,5);

        System.out.println(localDate.getDayOfWeek());

        System.out.println(localDate.getDayOfMonth());

        System.out.println(localDate.getDayOfYear());

 3.指定时间

LocalTime localTime = LocalTime.of(13,14,50);

        System.out.println(localTime.getHour());

        System.out.println(localTime.getMinute());

        System.out.println(localTime.getSecond());

Java 8 有哪些新特性的更多相关文章

  1. JAVA JDK1.5-1.9新特性

    1.51.自动装箱与拆箱:2.枚举(常用来设计单例模式)3.静态导入4.可变参数5.内省 1.61.Web服务元数据2.脚本语言支持3.JTable的排序和过滤4.更简单,更强大的JAX-WS5.轻量 ...

  2. Java 8 正式发布,新特性全搜罗

    经过2年半的努力.屡次的延期和9个里程碑版本,甲骨文的Java开发团队终于发布了Java 8正式版本. Java 8版本最大的改进就是Lambda表达式,其目的是使Java更易于为多核处理器编写代码: ...

  3. Java引入的一些新特性

    Java引入的一些新特性 Java 8 (又称为 jdk 1.8) 是 Java 语言开发的一个主要版本. Oracle 公司于 2014 年 3 月 18 日发布 Java 8 ,它支持函数式编程, ...

  4. 使用示例带你提前了解 Java 9 中的新特性

    使用示例带你提前了解 Java 9 中的新特性 转载来源:https://juejin.im/post/58c5e402128fe100603cc194 英文出处:https://www.journa ...

  5. Java学习之==>Java8 新特性详解

    一.简介 Java 8 已经发布很久了,很多报道表明Java 8 是一次重大的版本升级.Java 8是 Java 自 Java 5(发布于2004年)之后的最重要的版本.这个版本包含语言.编译器.库. ...

  6. JAVA笔记 之 JDK新特性

    JDK1.5新特性1.泛型(Generics) 为集合(collections)提供编译时类型安全,无需每刻从Collections取得一个对象就进行强制转换(cast) 2.增强的for循环(for ...

  7. Java系列 - 用Java8新特性进行Java开发太爽了

    本人博客文章网址:https://www.peretang.com/using-java8s-new-features-to-coding-is-awesome/ 前言 从开始写博客到现在已经过去3个 ...

  8. Java系列 – 用Java8新特性进行Java开发太爽了(续)

    本人博客文章网址:https://www.peretang.com/using-java8s-new-features-to-coding-is-awesome-2/ 前言 上周, 我们谈论了关于Ja ...

  9. Java各个版本的新特性

    原链接:http://blog.csdn.net/shareus/article/details/50736159 1.5 1.自动装箱与拆箱: 2.枚举(常用来设计单例模式) http://www. ...

  10. Java Servlet 3.0 新特性

    Servlet 3.0 新特性概述 Servlet 3.0 作为 Java EE 6 规范体系中一员,随着 Java EE 6 规范一起发布.该版本在前一版本(Servlet 2.5)的基础上提供了若 ...

随机推荐

  1. 时间类型:datetime,timestamp,date,time,year

    时间类型 1.年月日时分秒:datetime #取值范围# '1000-01-01 00:00:00'到'9999-12-31 23:59:59' 占存储8B:表示的范围比timestamp大:支持0 ...

  2. console.log 如何打印对象

    问题描述: var obj={a:1,b:2}; console.log(obj); 控制台返回的值是object. 解决方案: console.log(JSON.stringify(obj))

  3. python pip 安装常用库如何使用国内镜像源

    最近通过python安装一些常用库发现下载速度特别慢,而且还会出现无法安装等错误,尝试找了一些国内的镜像源,发现阿里云的速度很快,这里做个记录,并分享给大家. 国内镜像源 阿里云:http://mir ...

  4. js 设计模式:观察者和发布订阅模式

    总是把这两个当作同一个模式,但其实是不太一样的,现在重温一下. 观察者模式 观察者直接订阅目标,当目标触发事件时,通知观察者进行更新 简单实现 class Observer { constructor ...

  5. C#串口通信:MSComm控件使用详解

    目  次MSComm控件两种处理通讯的方式CommPort属性RThreshold 属性CTSHolding 属性SThreshold 属性CDHolding 属性DSRHolding 属性Setti ...

  6. JQuery checkbox多选框组选中提交,当选择某(无)一项,其他项禁止选中

    在项目中难免会遇到一些表单的提交,尤其是多选框中,当用户选择了某一项时,禁止其他项的选择.所以为了避免这样的冲突,所以我们前端就得控制一下了,下面就来个简单demo,记录一下,有需要的伙伴可以拿去耍耍 ...

  7. 文本编辑器EditPlus的安装

  8. C语言:找出一个大于给定整数m且紧随m的素数,-求出能整除x且不是偶数的数的个数,

    //函数fun功能:找出一个大于给定整数m且紧随m的素数,并作为函数值返回. #include <stdlib.h> #include <conio.h> #include & ...

  9. ASP.NET Core搭建多层网站架构【12-xUnit单元测试之集成测试】

    2020/02/01, ASP.NET Core 3.1, VS2019, xunit 2.4.1, Microsoft.AspNetCore.TestHost 3.1.1 摘要:基于ASP.NET ...

  10. 小白学 Python 爬虫(28):自动化测试框架 Selenium 从入门到放弃(下)

    人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 小白学 Python 爬虫(3):前置准备(二)Li ...