Java更快地对基元数组进行排序?

看起来Java的原语排序数组在不久的将来可能会提高性能。 弗拉基米尔·雅罗斯拉夫斯基(Vladimir Yaroslavskiy)已在core-libs-dev邮件列表中发布了一条消息 ,标题为“ Dual-Pivot Quicksort的新优化版本 ”,其中Yaroslavskiy撰写了“ Dual-Pivot Quicksort的优化和更快版本”,他已经“开始工作了”。在……过去5年中。”

新的Dual-Pivot Quicksort优化版本 ”消息包括有关Dual-Pivot Quicksort的一些历史背景; 突出显示了新版本在随机数据,“近乎结构化的数组”和“周期输入”方面的相对性能; 提供所涉及更改的全面摘要; 并提供用于更改的开放代码审查的链接

Dual-Pivot Quicksort算法是2009年引入Java的。Yaroslavskiy在2009年9月撰写的另一篇core-libs-dev邮件列表中 写道:用新的Dual-Pivot Quicksort替换java.util.Arrays中的Quicksort ”。 “我想与您分享新的Dual-Pivot Quicksort,它比已知的实现方式(理论上和实验上)都快。 我想建议用新的替代JDK的Quicksort实现。” 在描述“新的Dual-Pivot Quicksort如何使用* two *枢轴元素”而不是所有早期方案使用的单个枢轴元素之前,该帖子描述了“经典Quicksort算法”方案以及对该方案的一些修改。

原始消息“ 用新的Dual-Pivot Quicksort替换java.util.Arrays中的Quicksort ”具有一些其他有趣的历史细节,并在此处突出显示。

  • 乔恩·本特利(Jon Bentley)在一封邮件中写道:“我认为弗拉基米尔(Vladimir)对Quicksort的贡献远远超过了我所做的任何事情,并在Hoare的原始设计和Sedgewick的分析上位居前列。” 该消息还提供了有关快速排序的发展的简短但有趣的历史背景。 该信息充分说明了雅罗斯拉夫斯基的贡献,但我认为它也充分说明了乔恩·本特利的性格。
  • 乔什·布洛赫(Josh Bloch)在此消息中粘贴了一封电子邮件,其中说:“我相信,此代码不太可能最终被移植到多种语言并以Bentley和McIlroy很好的方式广泛部署(已成功实现20种成功年)。” 事实证明是这种情况,因为其他语言(或语言库)在某种程度上采用了该算法,并带有JavaScriptPythonRuby等示例。

通过在原始数组类型上使用Arrays.sort()方法的重载版本,可以看到新的改进版本的Dual-Pivot Quicksort可能带来的性能改进。 搜索词“ Dual-Pivot Quicksort”在与Arrays类的JDK 9版本相关的Javadoc生成HTML输出中出现14次:

因为quicksort仅用于对基元进行排序,所以对双数据点quicksort的这些性能增强仅影响基元上的方法,而不会影响倾向于使用合并排序的Arrays.sort(Object [])之类的方法。

据我所知,没有针对这些性能改进的特定Java版本,但是它们似乎已经进行了广泛的审查和测试,因此与基元数组排序有关的性能改进可能很快就会到来。您附近的Java版本。

参考文献

翻译自: https://www.javacodegeeks.com/2018/01/faster-sorting-arrays-primitives-coming-java.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值