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

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

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

[[181547]]

在本文中,我们就聊聊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<T>。

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


2.Flow类介绍

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

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

[[181548]]

就此,我们与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将二者关联起来。

[[181549]]

另一项元素为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<T>进行了扩展。Future适用于,当我们不希望或者不需要一个直接计算结果的时候,我们会收到一个 Future 对象来保存计算完成时分配的实际结果。

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

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

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


总结

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

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

 

原文链接:https://dzone.com/articles/the-essential-java-9-feature-you-probably-never-he

原文标题:The Essential Java 9 Feature You Probably Never Heard Of

作者:Henn Idan

【51CTO译稿,合作站点转载请注明原文译者和出处为51CTO.com】

责任编辑:关崇 来源: 51CTO
相关推荐

2017-01-15 17:15:27

Java基本功能

2014-09-17 10:16:41

Java 9

2010-06-28 21:33:17

eMule协议

2012-10-22 16:47:45

IBMdw

2020-10-19 10:16:02

AWSDynamoDB功能

2010-04-16 09:06:18

WPF 4

2019-04-16 08:21:46

2010-03-02 17:43:31

WCF框架处理流程

2010-01-05 15:27:04

.NET Framew

2019-09-16 08:22:12

特权访问管理PAM网络安全

2021-06-03 09:20:33

微服务架构代码

2011-04-29 14:04:56

一体机

2015-07-07 14:17:56

物联网操作系统

2010-01-20 18:20:50

2023-05-11 08:59:43

Nginx配置服务器

2018-12-19 12:23:24

复制粘贴WordIBM

2010-01-04 10:47:08

智能交换机

2010-08-17 09:01:39

jQueryAPI

2009-12-03 09:08:21

路由器基本功能

2013-09-03 09:42:13

Android开发者
点赞
收藏

51CTO技术栈公众号