Java 9为何让开发者如此兴奋,来看看它的这一基本功能!

简介:

Java 9即将在2017年7月正式发布,并提供一份关于新增和修订的功能以及一些特性的说明清单。对JDK增强提议(简称JEP)进行搜索时,我们发现了JEP 266中包含了:对CompletableFuture进行了不少更新,和更新了并发功能和要支持Reactive Streams机制相关的内容,这引起了我的注意。

Java 9为何让开发者如此兴奋,来看看它的这一基本功能!

在本文中,我们就聊聊JEP 266的新增和修订的功能吧,并且它很有可能成为Java 9 的特性之一。

1.Java 9将迎来哪些强化?

作为甲骨文公司起草的JDK增强提议(简称JEP)之一,它包含了很多有趣的更新,目的是用于解决并行机制相关的问题。

根据这份提议,Java 9将迎来以下变更与更新:

各接口支持Reactive Streams发布的订阅框架。

CompletableFuture API将得到全面改进,包括支持支持延迟、超时、子类化和其它方法。

更多小型调整与javadoc规范修改。

Java 9为何让开发者如此兴奋,来看看它的这一基本功能!

这里我们主要分析两项核心内容。第一项内容是Java 9将支持Reactive Streams,这个提议来自Java技术社区提出的改进计划,目的是改进开发者的并行工作流程。其次是CompletableFuture API的修复性提升,可以让开发者回到Future。

但这些都有怎样的实际意义呢?

2.Flow类介绍

第一项更新的“各接口支持Reactive Streams发布的订阅框架”,就是将新的Flow类嵌套进去,和可供开发者用于创建自定义组件的SubmissionPublisher。

让我们逐一进行讨论。Reactive Streams能够解决背压(back-pressure)难题。当输入任务速率高于系统的处理能力时,就会发生数据累积并会对未处理数据提供一个缓冲区。

Java 9为何让开发者如此兴奋,来看看它的这一基本功能!

就此,我们与Reactive Streams开发团队Akka高级开发者Konrad Malawski进行了交流,他解释了Reactive Streams 的重要性以及如何使用。

甲骨文方面指出,这项新增强将包含“一套小型接口,用以对接Reactive Streams项目中各类得到广泛使用的定义接口。”

而Flow类的作用也正在于此。Reactive Steams由4个Java接口构建而成:

处理器(Processor)

发布商(Publisher)

订阅用户(Subscriber)

订阅(Subscription)

Flow类允许各互关联接口与静态方法建立受控流程组件,发布者产生由一个或多个订阅者消费的项目,每个订阅者由订阅管理。

Reactive Streams位于容器对象java.util.concurrent.Flow之下。大开发者可以在这里找到 Flow.Publisher,一个用作 lambda 表达式或方法引用的赋值目标功能接口。此接口将显著简化面向Flow.Subscription的元素生成方式,并由Flow.Subscription将二者关联起来。

Java 9为何让开发者如此兴奋,来看看它的这一基本功能!

另一项元素为Flow.Subscriber,是用异步工作机制运作,并能通过请求实现触发。它能能够从Flow.Subscription处获取多个元素,大家可根据需求自定义缓冲区大小。

这些接口同时适用于并发与分布式异步设置,且接口之间的通信,是通过一种简单的流控制形式实现,并可用于避免发生资源管理的问题。

感兴趣的朋友可以查看关于java.util.concurrent.Flow的代码示例。转到此处:http://gee.cs.oswego.edu/dl/concurrency-interest/index.html/

另外,大家也无需等待Java 9正式发布即可体验Reactive Streams接口,目前也已经在多种第三方库采用此类接口。

3.CompletableFuture新特性

Java 8首次引入CompletableFuture是,就已经对Future进行了扩展。Future适用于,当我们不希望或者不需要一个直接计算结果的时候,我们会收到一个 Future 对象来保存计算完成时分配的实际结果。

Java 9为何让开发者如此兴奋,来看看它的这一基本功能!

CompletableFuture对Future对象做出两方面扩展。其能够在无需任何异步等待的情况下,通过调用complete()方法即可显式完成。另外,它还允许利用一系列操作中,构建起数据处理管道。

如此一来,任意类型的值皆能在 Future 中使用默认返回值,即使当前计算尚未完成,它也可使用默认即时结果。这些更新将能够有效解决开发者在使用Java 8时面临的部分难题。

总结

Java 9确实为我们带来一系列重大更新与改进,其中 JEP 266 会是最有趣的一部分改进。另外,我们认为JEP 266,也是甲骨文发布的最值得关注的更新之一,因为其源自技术社区本身的倡议,旨在帮助开发者解决异步流程处理中的一些常见难题。我们对此深表赞赏,同时也期待着Java 9的正式发布。

本文转自d1net(转载)

相关文章
|
4月前
|
SQL Java 数据库连接
为何JDBC是Java开发者的“心头好”?原因竟然这么简单!
为何JDBC是Java开发者的“心头好”?原因竟然这么简单!
41 3
|
1月前
|
安全 Java 测试技术
🎉Java零基础:全面解析枚举的强大功能
【10月更文挑战第19天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
108 60
|
4月前
|
安全 Java API
告别繁琐编码,拥抱Java 8新特性:Stream API与Optional类助你高效编程,成就卓越开发者!
【8月更文挑战第29天】Java 8为开发者引入了多项新特性,其中Stream API和Optional类尤其值得关注。Stream API对集合操作进行了高级抽象,支持声明式的数据处理,避免了显式循环代码的编写;而Optional类则作为非空值的容器,有效减少了空指针异常的风险。通过几个实战示例,我们展示了如何利用Stream API进行过滤与转换操作,以及如何借助Optional类安全地处理可能为null的数据,从而使代码更加简洁和健壮。
119 0
|
2月前
|
前端开发 Java 数据库连接
Spring 框架:Java 开发者的春天
Spring 框架是一个功能强大的开源框架,主要用于简化 Java 企业级应用的开发,由被称为“Spring 之父”的 Rod Johnson 于 2002 年提出并创立,并由Pivotal团队维护。
57 1
Spring 框架:Java 开发者的春天
|
19天前
|
Java
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式。本文介绍了 Streams 的基本概念和使用方法,包括创建 Streams、中间操作和终端操作,并通过多个案例详细解析了过滤、映射、归并、排序、分组和并行处理等操作,帮助读者更好地理解和掌握这一重要特性。
25 2
|
2月前
|
Java 数据库连接 开发者
Spring 框架:Java 开发者的春天
【10月更文挑战第27天】Spring 框架由 Rod Johnson 在 2002 年创建,旨在解决 Java 企业级开发中的复杂性问题。它通过控制反转(IOC)和面向切面的编程(AOP)等核心机制,提供了轻量级的容器和丰富的功能,支持 Web 开发、数据访问等领域,显著提高了开发效率和应用的可维护性。Spring 拥有强大的社区支持和丰富的生态系统,是 Java 开发不可或缺的工具。
|
2月前
|
存储 算法 Java
Java的Set集合以其严格的“不重复性”著称,使开发者既好奇又困惑
Java的Set集合以其严格的“不重复性”著称,使开发者既好奇又困惑。本文将探讨Set为何如此“挑剔”。Set接口不包含重复元素,适用于需要唯一性约束的场景。其内部通过哈希表或红黑树等数据结构和哈希算法、equals()方法来确保元素的唯一性。示例代码展示了Set如何自动过滤重复元素,体现了其高效性和便利性。
37 2
|
2月前
|
Java 程序员
在Java编程中,关键字不仅是简单的词汇,更是赋予代码强大功能的“魔法咒语”。
【10月更文挑战第13天】在Java编程中,关键字不仅是简单的词汇,更是赋予代码强大功能的“魔法咒语”。本文介绍了Java关键字的基本概念及其重要性,并通过定义类和对象、控制流程、访问修饰符等示例,展示了关键字的实际应用。掌握这些关键字,是成为优秀Java程序员的基础。
25 3
|
2月前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
58 2
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
|
2月前
|
Java 数据安全/隐私保护
Java ffmpeg 实现视频加文字/图片水印功能
【10月更文挑战第22天】在 Java 中使用 FFmpeg 实现视频加文字或图片水印功能,需先安装 FFmpeg 并添加依赖(如 JavaCV)。通过构建 FFmpeg 命令行参数,使用 `drawtext` 滤镜添加文字水印,或使用 `overlay` 滤镜添加图片水印。示例代码展示了如何使用 JavaCV 实现文字水印。
103 1