BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Java 8新闻:发布候选版面世、新的原子数、放弃简易实现(Stripped Implementations)

| 作者 Matt Raible 关注 12 他的粉丝 ,译者 臧秀涛 关注 4 他的粉丝 发布于 2014年2月19日. 估计阅读时间: 5 分钟 | QCon上海2018 关注大数据平台技术选型、搭建、系统迁移和优化的经验。

Java 8的第一个发布候选版(RC)已于2月初面世。第一个发布候选版b128是2月4日发布的,第二个版本则于一周后在OpenJDK邮件列表中宣告问世

Java 8 RC2修复了新的Comparator API中的一个严重缺陷——新的thenComparing()方法有一个不必要的类型约束。bug报告指出:

在java.util.Comparator中,下面的方法要求类型U扩展java.lang.Comparable。

<U extends Comparable<? super U>> Comparator<T> thenComparing( 
Function<? super T, ? extends U> keyExtractor, 
Comparator<? super U> keyComparator);

但是这一约束是不必要的,因为keyComparator用于比较的是提取出的key对象。

Java 8 RC2还修复了在Mac OS X上的一个读权限问题。发布候选版可以从https://jdk8.java.net/download.html下载。

根据JDK 8的bug跟踪系统上的信息,Java 8将于3月17日圣帕特里克节这天发布。截至本文写作时,还有3个问题尚未解决,都与文档有关。

在其他与Java 8有关的新闻中,Drew Stephens最近发布的数据表明,Java 8的原子数实现快了很多。此外,出于法律方面的原因,Mark Reinhold提议放弃简易实现(Stripped Implementations)。

新的原子数实现

除了Lambdas(335)和新的日期与时间API(JSR 310),Java 8还包含了对特定的多线程应用类非常重要的原子数实现。Palamino Labs的负责人Drew Stephens最近撰文谈到了LongAdder和DoubleAdder的引入

尽管LongAdderDoubleAdder的引入不是那么光彩夺目,但是对于特定的多线程应用类而言,非常重要。这两个原子数实现在多线程竞态条件下提供了比AtomicIntegerAtomicLong更好的性能。

一些简单的基准测试就能说明其性能差别,下面的基准测试,我们使用了一个m3.2xlarge EC2实例,它可以访问一个Intel Xeon E5-2670处理器的全部8个核心。

在单线程条件下,新的LongAdder会慢1/3,但是当多个线程竞争着增加字段时,LongAdder就体现出了其价值。请注意,每个线程唯一要做的是尝试增加计数器——这是一个最极端的综合基准测试。这里的竞争比你现实中可能看到的大部分应用更为强烈,但有时你确实需要这类共享计数器,而LongAdder能提供很大的帮助。

Drew继续演示了AtomicLong,它在单线程条件下快一点。然而,在使用两个线程时,它要慢4倍;当线程数与核数相同时,它几乎慢5倍。他还指出,“当线程数超过CPU的物理核数时,LongAdder的性能就保持恒定了”。

放弃简易实现

简易实现是Java 8的一个计划特性,支持将Java SE的定制实现与要基于它运行的应用打包到一起。不依赖应用所使用代码的元素可以移除。对于想把Java嵌入到设备中的应用,这类实现可能是有用的(比如家用设备)。

Mark Reinhold最近提议从Java SE 8中去掉简易实现。他援引了法律问题作为理由。

为保持兼容性并防止分裂,Java SE 8的简易实现特性需要对TCK许可做一些重大的修改。

我已经和Oracle的法务部门就这些修订共同工作过一段时间。我们有一个初始草案,但是现在遗憾的是,我认为专家组成员、JCP执行委员会成员和其他各方已经没有足够的时间审阅和评注这些修改了。

因此我建议从Java SE 8中去掉简易实现特性。这只需要修改规范和TCK规则,不需要修改参考实现或实际的TCK测试。

Reinhold还写道,他认为简易实现对于Java平台的未来很是重要,该特性可能会在Java SE 9之前的版本中加入。

Java 8的发布已经近在咫尺。更易用的日期、闭包、更好的并发和一个新的JavaScript引擎,离我们只有一个月之遥了!你会升级吗?如果不升级,是有技术方面的原因阻止你升级吗?

查看英文原文:Java 8 News: Release Candidates Available, New Atomic Numbers and Stripped Implementations Dropped

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT