《Java工程师必读手册》——Java极客主义系列——最完美的Lambda表达式只有一行(6)

简介: 《Java工程师必读手册》——Java极客主义系列——最完美的Lambda表达式只有一行(6)

接上篇:

https://developer.aliyun.com/article/1226755?spm=a2c6h.12873581.technical-group.dArticle1226755.524d5a5cxQxTxO

七、 Lambda表达式实践

 

上面介绍了这么多知识,这章将详细介绍Lambda表达式的实践。这里,将以ODPS查询封装为例子,详细地介绍如何使用和优化Lambda表达式。

 

1. 查询ODPS数据代码

 

这里,有一段查询公司雇员的方法:

 

image.png

 

类似地,还有几段从ODPS查询数据的代码。

 

2. 利用内部类进行优化

 

因为上面代码的重复性,我们可以采用设计模式——模板方法模式(Template Method Pattern),把相同的部分固化下来,并把不同的部分抽象出接口。那么,我们就抽象出一个接口DataParser(数据解析器),并把ODPS数据查询固化到OdpsService的executeQuery方法中。

 

image.png

 

那么,采用匿名内部类的编写方法,可以把queryEmployee改为:

 

image.png

 

 

3. 利用Lambda表达式优化

 

从上面例子可以看出,利用内部类实现queryEmployee方法,由于模式代码比较多,显得代码比较啰嗦。这里,利用Lambda表达式进行优化。

 

image.png

 

可以看出,代码量大大地减少了。

 

4. 去掉自定义的函数式接口

 

为了减少代码中自定义函数式接口,可以利用Java提供的4个基本函数式接口。这里,我们采用函数接口“FunctionT>”替换掉“DataParser”。

 

image.png

 

5. 利用提取方法优化Lambda表达式

 

上面的例子中,最大的问题就是——Lambda表达式理解困难,没有一个名称或注释,需要看完Lambda表达式后才能理解。通过第6章的方法,可以把Lambda表达式抽象成一个方法,从而达到优化Lambda表达式的目的。

 

image.png

 

6. 利用方法引用优化Lambda表达式

 

我们使用Lambda表达式,就是希望代码更精简。上面例子中,Lambda表达式还可以采用方法引用的方式进行精简,从而最终达到“完美的Lambda表达式只有一行”的目标。

 

image.png

 

7. 变化1:需要传递参数或变量

 

如果需要把方法参数companyId传给每一个EmployeeDO对象,最终的代码如下:

 

image.png

 

8. 变化2:需要抽象出多个方法

 

如果需要抽象出多个方法,还想使用函数式编程,就需要声明多个函数式接口参数。比如:分批查询并保存数据。

 

image.png

 

注意

“parseEmployee”被定义为static方法,方法引用为“EmployeeService::parseEmployee”;而“storageEmployee”被定义为private方法,方法引用为this::storageEmployee。具体原因,请参考第3章。

 

9. 总结:由繁至简,由简至明

 

通过这个过程,可以总结出一个使用Lambda表达式的历程——“由繁至简,由简至明”:

 

1) 由繁至简

 

通过Lambda表达式,消除了很多模式代码,把复杂的代码进行简化;但是,也正由于代码过于简略,失去了代码可读性和可维护行。

 

2) 由简至明

 

为了提高代码的可读性和可维护行,又不得不损失一些简化,利用提取方法等机制,让Lambda表达式变得更明确。


接下篇:https://developer.aliyun.com/article/1226748?groupCode=java

 

相关实践学习
简单用户画像分析
本场景主要介绍基于海量日志数据进行简单用户画像分析为背景,如何通过使用DataWorks完成数据采集 、加工数据、配置数据质量监控和数据可视化展现等任务。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
相关文章
|
2天前
|
Java 程序员 编译器
JavaSE&Java8 Lambda 表达式
JavaSE&Java8 Lambda 表达式
|
6天前
|
并行计算 Java 编译器
Java Lambda表达式简介
Java Lambda表达式简介
12 0
|
7天前
|
Java API
Java Lambda
Java Lambda
15 0
|
7天前
|
Java 开发者
探索 Java 的函数式接口和 Lambda 表达式
【4月更文挑战第19天】Java 中的函数式接口和 Lambda 表达式提供了简洁、灵活的编程方式。函数式接口有且仅有一个抽象方法,用于与 Lambda(一种匿名函数语法)配合,简化代码并增强可读性。Lambda 表达式的优点在于其简洁性和灵活性,常用于事件处理、过滤和排序等场景。使用时注意兼容性和变量作用域,它们能提高代码效率和可维护性。
|
10天前
|
分布式计算 Java API
Java 8新特性之Lambda表达式与Stream API
【4月更文挑战第16天】本文将介绍Java 8中的两个重要新特性:Lambda表达式和Stream API。Lambda表达式是Java 8中引入的一种新的编程语法,它允许我们将函数作为参数传递给其他方法,从而使代码更加简洁、易读。Stream API是Java 8中引入的一种新的数据处理方式,它允许我们以声明式的方式处理数据,从而使代码更加简洁、高效。本文将通过实例代码详细讲解这两个新特性的使用方法和优势。
|
14天前
|
Java
Java 14 强势登场:Switch 表达式的进化之路
Java 14 强势登场:Switch 表达式的进化之路
18 0
|
3天前
|
安全 Java 调度
Java线程:深入理解与实战应用
Java线程:深入理解与实战应用
20 0
|
1天前
|
消息中间件 缓存 NoSQL
Java多线程实战-CompletableFuture异步编程优化查询接口响应速度
Java多线程实战-CompletableFuture异步编程优化查询接口响应速度
|
1天前
|
数据采集 存储 Java
高德地图爬虫实践:Java多线程并发处理策略
高德地图爬虫实践:Java多线程并发处理策略