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

本文涉及的产品
云原生大数据计算服务 MaxCompute,5000CU*H 100GB 3个月
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介: 《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

 

相关实践学习
基于MaxCompute的热门话题分析
本实验围绕社交用户发布的文章做了详尽的分析,通过分析能得到用户群体年龄分布,性别分布,地理位置分布,以及热门话题的热度。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
相关文章
|
1月前
|
Java API 开发者
Java中的Lambda表达式与Stream API的协同作用
在本文中,我们将探讨Java 8引入的Lambda表达式和Stream API如何改变我们处理集合和数组的方式。Lambda表达式提供了一种简洁的方法来表达代码块,而Stream API则允许我们对数据流进行高级操作,如过滤、映射和归约。通过结合使用这两种技术,我们可以以声明式的方式编写更简洁、更易于理解和维护的代码。本文将介绍Lambda表达式和Stream API的基本概念,并通过示例展示它们在实际项目中的应用。
|
2月前
|
Java API 开发者
Java中的Lambda表达式:简洁代码的利器####
本文探讨了Java中Lambda表达式的概念、用途及其在简化代码和提高开发效率方面的显著作用。通过具体实例,展示了Lambda表达式如何在Java 8及更高版本中替代传统的匿名内部类,使代码更加简洁易读。文章还简要介绍了Lambda表达式的语法和常见用法,帮助开发者更好地理解和应用这一强大的工具。 ####
|
2月前
|
并行计算 Java 编译器
深入理解Java中的Lambda表达式
在Java 8中引入的Lambda表达式,不仅简化了代码编写,还提升了代码可读性。本文将带你探索Lambda表达式背后的逻辑与原理,通过实例展示如何高效利用这一特性优化你的程序。
|
1月前
|
安全 Java API
Java中的Lambda表达式:简化代码的现代魔法
在Java 8的发布中,Lambda表达式的引入无疑是一场编程范式的革命。它不仅让代码变得更加简洁,还使得函数式编程在Java中成为可能。本文将深入探讨Lambda表达式如何改变我们编写和维护Java代码的方式,以及它是如何提升我们编码效率的。
|
2月前
|
安全 Java API
Java中的Lambda表达式与Stream API的高效结合####
探索Java编程中Lambda表达式与Stream API如何携手并进,提升数据处理效率,实现代码简洁性与功能性的双重飞跃。 ####
30 0
|
设计模式 搜索推荐 Java
Java 极客技术 2019 年高考语文卷
Java 极客技术 2019 年高考语文卷
|
2天前
|
监控 Java
java异步判断线程池所有任务是否执行完
通过上述步骤,您可以在Java中实现异步判断线程池所有任务是否执行完毕。这种方法使用了 `CompletionService`来监控任务的完成情况,并通过一个独立线程异步检查所有任务的执行状态。这种设计不仅简洁高效,还能确保在大量任务处理时程序的稳定性和可维护性。希望本文能为您的开发工作提供实用的指导和帮助。
32 17
|
12天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
|
14天前
|
安全 Java Kotlin
Java多线程——synchronized、volatile 保障可见性
Java多线程中,`synchronized` 和 `volatile` 关键字用于保障可见性。`synchronized` 保证原子性、可见性和有序性,通过锁机制确保线程安全;`volatile` 仅保证可见性和有序性,不保证原子性。代码示例展示了如何使用 `synchronized` 和 `volatile` 解决主线程无法感知子线程修改共享变量的问题。总结:`volatile` 确保不同线程对共享变量操作的可见性,使一个线程修改后,其他线程能立即看到最新值。
|
14天前
|
消息中间件 缓存 安全
Java多线程是什么
Java多线程简介:本文介绍了Java中常见的线程池类型,包括`newCachedThreadPool`(适用于短期异步任务)、`newFixedThreadPool`(适用于固定数量的长期任务)、`newScheduledThreadPool`(支持定时和周期性任务)以及`newSingleThreadExecutor`(保证任务顺序执行)。同时,文章还讲解了Java中的锁机制,如`synchronized`关键字、CAS操作及其实现方式,并详细描述了可重入锁`ReentrantLock`和读写锁`ReadWriteLock`的工作原理与应用场景。