【Java8新特性】面试官:谈谈Java8中的Stream API有哪些终止操作?(1)

最后

小编在这里分享些我自己平时的学习资料,由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

开源分享:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】

程序员代码面试指南 IT名企算法与数据结构题目最优解

这是” 本程序员面试宝典!书中对IT名企代码面试各类题目的最优解进行了总结,并提供了相关代码实现。针对当前程序员面试缺乏权威题目汇总这一-痛点, 本书选取将近200道真实出现过的经典代码面试题,帮助广“大程序员的面试准备做到万无一失。 “刷”完本书后,你就是“题王”!

image.png

《TCP-IP协议组(第4版)》

本书是介绍TCP/IP协议族的经典图书的最新版本。本书自第1版出版以来,就广受读者欢迎。

本书最新版进行」护元,以体境计算机网络技不的最新发展,全书古有七大部分共30草和7个附录:第一部分介绍一些基本概念和基础底层技术:第二部分介绍网络层协议:第三部分介绍运输层协议;第四部分介绍应用层协议:第五部分介绍下一代协议,即IPv6协议:第六部分介绍网络安全问题:第七部分给出了7个附录。

image.png

Java开发手册(嵩山版)

这个不用多说了,阿里的开发手册,每次更新我都会看,这是8月初最新更新的**(嵩山版)**

image.png

MySQL 8从入门到精通

本书主要内容包括MySQL的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL 函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与还原、MySQL 日志、性能优化、MySQL Repl ication、MySQL Workbench、 MySQL Utilities、 MySQL Proxy、PHP操作MySQL数据库和PDO数据库抽象类库等。最后通过3个综合案例的数据库设计,进步讲述 MySQL在实际工作中的应用。

image.png

Spring5高级编程(第5版)

本书涵盖Spring 5的所有内容,如果想要充分利用这一领先的企业级 Java应用程序开发框架的强大功能,本书是最全面的Spring参考和实用指南。

本书第5版涵盖核心的Spring及其与其他领先的Java技术(比如Hibemate JPA 2.Tls、Thymeleaf和WebSocket)的集成。本书的重点是介绍如何使用Java配置类、lambda 表达式、Spring Boot以及反应式编程。同时,将与企业级应用程序开发人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。

image.png

JAVA核心知识点+1000道 互联网Java工程师面试题

image.png

image.png

企业IT架构转型之道 阿里巴巴中台战略思想与架构实战

本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。

image.png

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

Optional findAny();

我们可以通过类似如下示例来使用findAny()方法。

Optional op = employees.stream().filter((e) -> Employee.Stauts.WORKING.equals(e.getStauts())).findFirst();

System.out.println(op.get());

6.count()方法

count()方法表示返回流中元素总数。其在Stream接口中的定义如下所示。

long count();

我们可以通过类似如下示例来使用count()方法。

long count = employees.stream().count();

System.out.println(count);

7.max()方法

max()方法表示返回流中最大值。其在Stream接口中的定义如下所示。

Optional max(Comparator<? super T> comparator);

我们可以通过类似如下示例来使用max()方法。

Optional op = employees.stream().max((e1, e2) -> Double.compare(e1.getSalary(), e2.getSalary()));

System.out.println(op.get());

8.min()方法

min()方法表示返回流中最小值。其在Stream接口中的定义如下所示。

Optional min(Comparator<? super T> comparator);

我们可以通过类似如下示例来使用min()方法。

Optional op = employees.stream().map(Employee::getSalary).min(Double::compare);

System.out.println(op.get());

9.forEach()方法

forEach()方法表示内部迭代(使用 Collection 接口需要用户去做迭代,称为外部迭代。相反, Stream API 使用内部迭代)。其在Stream接口内部的定义如下所示。

void forEach(Consumer<? super T> action);

我们可以通过类似如下示例来使用forEach()方法。

employees.stream().forEach(System.out::println);

规约


Stream API中有关规约的方法如下表所示。

| 方法 | 描述 |

| — | — |

| reduce(T iden, BinaryOperator b) | 可以将流中元素反复结合起来,得到一个值。 返回 T |

| reduce(BinaryOperator b) | 可以将流中元素反复结合起来,得到一个值。 返回 Optional |

reduce()方法在Stream接口中的定义如下所示。

T reduce(T identity, BinaryOperator accumulator);

Optional reduce(BinaryOperator accumulator);

U reduce(U identity, BiFunction<U, ? super T, U> accumulator, BinaryOperator combiner);

我们可以通过类似如下示例来使用reduce方法。

List list = Arrays.asList(1,2,3,4,5,6,7,8,9,10);

Integer sum = list.stream().reduce(0, (x, y) -> x + y);

System.out.println(sum);

System.out.println(“----------------------------------------”);

Optional op = employees.stream().map(Employee::getSalary).reduce(Double::sum);

System.out.println(op.get());

我们也可以搜索employees列表中“张”出现的次数。

Optional sum = employees.stream()

.map(Employee::getName)

.flatMap(TestStreamAPI1::filterCharacter)

.map((ch) -> {

if(ch.equals(‘六’))

return 1;

else

return 0;

}).reduce(Integer::sum);

System.out.println(sum.get());

注意:上述例子使用了硬编码的方式来累加某个具体值,大家在实际工作中再优化代码。

收集


| 方法 | 描述 |

| — | — |

| collect(Collector c) | 将流转换为其他形式。接收一个 Collector接口的实现,用于给Stream中元素做汇总的方法 |

collect()方法在Stream接口中的定义如下所示。

R collect(Supplier supplier,

BiConsumer<R, ? super T> accumulator,

BiConsumer<R, R> combiner);

<R, A> R collect(Collector<? super T, A, R> collector);

我们可以通过类似如下示例来使用collect方法。

Optional max = employees.stream()

.map(Employee::getSalary)

.collect(Collectors.maxBy(Double::compare));

System.out.println(max.get());

Optional op = employees.stream()

.collect(Collectors.minBy((e1, e2) -> Double.compare(e1.getSalary(), e2.getSalary())));

System.out.println(op.get());

Double sum = employees.stream().collect(Collectors.summingDouble(Employee::getSalary));

System.out.println(sum);

Double avg = employees.stream().collect(Collectors.averagingDouble(Employee::getSalary));

System.out.println(avg);

Long count = employees.stream().collect(Collectors.counting());

System.out.println(count);

System.out.println(“--------------------------------------------”);

DoubleSummaryStatistics dss = employees.stream()

.collect(Collectors.summarizingDouble(Employee::getSalary));

System.out.println(dss.getMax());

如何收集Stream流?


Collector接口中方法的实现决定了如何对流执行收集操作(如收集到 List、 Set、 Map)。 Collectors实用类提供了很多静态方法,可以方便地创建常见收集器实例, 具体方法与实例如下表:

| 方法 | 返回类型 | 作用 |

| — | — | — |

| toList | List | 把流中元素收集到List |

| toSet | Set | 把流中元素收集到Set |

| toCollection | Collection | 把流中元素收集到创建的集合 |

| counting | Long | 计算流中元素的个数 |

| summingInt | Integer | 对流中元素的整数属性求和 |

| averagingInt | Double | 计算流中元素Integer属性的平均 值 |

| summarizingInt | IntSummaryStatistics | 收集流中Integer属性的统计值。 如:平均值 |

| joining | String | 连接流中每个字符串 |

| maxBy | Optional | 根据比较器选择最大值 |

| minBy | Optional | 根据比较器选择最小值 |

| reducing | 归约产生的类型 | 从一个作为累加器的初始值 开始,利用BinaryOperator与 流中元素逐个结合,从而归 约成单个值 |

| collectingAndThen | 转换函数返回的类型 | 包裹另一个收集器,对其结 果转换函数 |

| groupingBy | Map<K, List> | 根据某属性值对流分组,属 性为K,结果为V |

| partitioningBy | Map<Boolean, List> | 根据true或false进行分区 |

每个方法对应的使用示例如下表所示。

| 方法 | 使用示例 |

| — | — |

| toList | List employees= list.stream().collect(Collectors.toList()); |

| toSet | Set employees= list.stream().collect(Collectors.toSet()); |

| toCollection | Collection employees=list.stream().collect(Collectors.toCollection(ArrayList::new)); |

| counting | long count = list.stream().collect(Collectors.counting()); |

| summingInt | int total=list.stream().collect(Collectors.summingInt(Employee::getSalary)); |

| averagingInt | double avg= list.stream().collect(Collectors.averagingInt(Employee::getSalary)) |

| summarizingInt | IntSummaryStatistics iss= list.stream().collect(Collectors.summarizingInt(Employee::getSalary)); |

| Collectors | String str= list.stream().map(Employee::getName).collect(Collectors.joining()); |

| maxBy | Optionalmax= list.stream().collect(Collectors.maxBy(comparingInt(Employee::getSalary))); |

| minBy | Optional min = list.stream().collect(Collectors.minBy(comparingInt(Employee::getSalary))); |

| reducing | int total=list.stream().collect(Collectors.reducing(0, Employee::getSalar, Integer::sum)); |

| collectingAndThen | int how= list.stream().collect(Collectors.collectingAndThen(Collectors.toList(), List::size)); |

| groupingBy | Map<Emp.Status, List> map= list.stream() .collect(Collectors.groupingBy(Employee::getStatus)); |

| partitioningBy | Map<Boolean,List>vd= list.stream().collect(Collectors.partitioningBy(Employee::getManage)); |

public void test4(){

Optional max = emps.stream()

.map(Employee::getSalary)

.collect(Collectors.maxBy(Double::compare));

System.out.println(max.get());

Optional op = emps.stream()

.collect(Collectors.minBy((e1, e2) -> Double.compare(e1.getSalary(), e2.getSalary())));

System.out.println(op.get());

Double sum = emps.stream()

.collect(Collectors.summingDouble(Employee::getSalary));

System.out.println(sum);

Double avg = emps.stream()

.collect(Collecors.averagingDouble(Employee::getSalary));

System.out.println(avg);

Long count = emps.stream()

.collect(Collectors.counting());

DoubleSummaryStatistics dss = emps.stream()

总结

无论是哪家公司,都很重视高并发高可用的技术,重视基础,重视JVM。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。

最后我整理了一些面试真题资料,技术知识点剖析教程,还有和广大同仁一起交流学习共同进步,还有一些职业经验的分享。

面试了阿里,滴滴,网易,蚂蚁,最终有幸去了网易【面试题分享】

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

DoubleSummaryStatistics dss = emps.stream()

总结

无论是哪家公司,都很重视高并发高可用的技术,重视基础,重视JVM。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。

最后我整理了一些面试真题资料,技术知识点剖析教程,还有和广大同仁一起交流学习共同进步,还有一些职业经验的分享。

[外链图片转存中…(img-MJgjneCe-1715477376965)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值