HarmonyOS开发者限时福利来啦!最高10w+现金激励等你拿~ 了解详情
写点什么

Sun 的 JDK7、OpenJDK 及 IcedTea 释疑

  • 2009-01-16
  • 本文字数:1791 字

    阅读完需:约 6 分钟

由于 JDK7 OpenJDK IcedTea 都是并行发展的,它们之间到底是什么关系很容易让人迷惑。OpenJDK 的质量主管 David Herron,试图澄清相关情况并解释为什么 JDK7 花费了这么长时间。

David 先描述了 OpenJDK 6 和 JDK 6 之间的不同:

OpenJDK 6 是 OpenJDK 7 的一个分支,为了通过 JCK 6 测试条件的检验,我们团队从 OpenJDK 7 分支上剥离出了很多代码,直到它符合 Java 6 规范为止。 关键是 OpenJDK 6 工作得非常好,好几个 Linux 的发行版都使用它作为其 JDK,它能够通过 JCK6 测试套件的测试,这意味着 OpenJDK 6 可以被用来构建一个兼容的 JDK,但是很不幸,我们所希望的这种进化轨迹相对来说是短期的。它服务于一个目的,即,拥有一个兼容 Java6 的完全开放的 OpenJDK。

接着,他谈到了 OpenJDK 和 IcedTea 的关系:

看上去有些人非常喜欢用“./configure”而不是设置环境变量,并运行“make”。IcedTea 项目最初是由于 OpenJDK 不完整(因产权 而造成的障碍)而创立的,社区需要一个完整的开源工具链及代码库。IcedTea 长期以来一直是 OpenJDK 的一套补丁,正如刚才我所说到的,它有一个 基于“./configure”的不同的构建系统。 在 OpenJDK 中,我们已经替换了产权代码(encumbered code),因此不再有障碍了。正因为我们的努力,IcedTea 项目已经减少了使用补丁的数量。IcedTea 中看上去不错的一点是,它的 configure 脚本使得在多种不同的模式下构建 OpenJDK 变得很容易,比如使用 Zero Assembler Port 在非 x86/sparc 芯片上来支持编译等等。 IcedTea 提供的一大块内容是 plugin/java-web-start 基础架构。我们还没有把我们的 plugin 开源,并且对于 6u10 我们重写 了该 plugin。人们都希望把新 plugin 开源给 OpenJDK 项目,但是据我所知,这一决定还没有提到议事日程。

David 表示 JDK7 和 OpenJDK7 将拥有(几乎)同一个代码库:

……计划 OpenJDK7/JDK7 的起点代码库将几乎一样。维护分支显然是昂贵的,如果 JDK7 与 OpenJDK7 差异太大,会导致两个结果:a) 非常 昂贵,b) 破坏我们在开源生态系统上所做的努力。 但是“几乎一样”代表着还是有一些不同。 还记得因产权而造成的障碍吗?其中有一些是截至 2007 年 5 月之前不能开源的代码(现在已经可以开源了),而另一些则还未得到同意(比如 SNMP),但是 有一些开源代码可以替换我们仍在使用的老的还未开源的那一部分代码。这些主要集中在字体及图形光栅部分。这些老的未开源光栅代码,尽管是有产权的且经过了 10 余年的修正和精调(有较好的质量质量保证),但是对于产生 JDK 构建的开源替代品来说,它们与现存非开源代码一样快速、稳定且拥有非常好的质量。

按照 David 的说法,OpenJDK 源码发布、JavaFX 以及整体资源不足是导致 JDK7 花了这么长时间的原因:

要是我们按照正常模式走,JDK7 现在就应该已经出来了。即,Java6 是于 2006 年 12 月发布的,而我们的正常模式是两个主版本之间间隔 18-24 个月,这意味着 JDK7 应该在 2-5 个月之前就已经发布了。到底怎么回事呢?很明显是几个方面的资源短缺。 比如,2007 年 5 月发布的近乎完整的 OpenJDK 源码花费了大量人力物力。但是在 2007 年 5 月的 JavaONE 大会上又宣布了一个产品(一个叫做 JavaFX 的小家伙),它又变成了对 Java 的一个较大调整(正如一些人所说,它不是原来那个 Java 了),而且也耗费了大量的工作。 换句话说,生产 JDK7 的时间被用来做 JDK6u10 和 JavaFX 了。

Joe Winchester 最近在 Java Developers Journal 的一篇文章上表达了关于 JavaFX 减缓了平台发展的类似主张,他将 Java 采用动态语言和类似 JavaFX 的技术,与 90 年代 Smalltalk 团队要把 Java 运行在其 VM(叫做统一 VM—— Universal VM)上所做的努力进行了对比。该作者指出,就像 Smalltalk 的情况一样,最好应该把精力集中在 Java 自身上,“而不是扩充 JVM 把它变成万金油 ”。

还要注意的是 OpenJDK 理事会即将寿终就寝,像 Neal Gafter 这样的人还关心着该组织新的组成形式

OpenJDK 理事会已经延期一年了,在 4 个月之内就要解散,有两个非 Sun 的位置仍然空缺。2008 年 4 月公布的最近一次会议备忘录中,大家一致同意在 2008 年底之前起草出宪章草案。 理事会的七个成员都是谁?我们能够看到 4 月之后的会议备忘录并获得宪章方面的现状报告吗?

你怎么看 Sun 的 JDK 以及开源Java 的未来呢?

查看英文原文: Sun’s JDK7, OpenJDK & IcedTea: Disambiguation

2009-01-16 07:576969
用户头像

发布了 150 篇内容, 共 45.6 次阅读, 收获喜欢 10 次。

关注

评论

发布
暂无评论
发现更多内容

SICP,我的函数式编程启蒙书

Kurtis Moxley

读书 函数式编程

全面剖析PHP-FPM+Nginx通信原理

书旅

nginx 正向代理与反向代理 PHP-FPM

年轻的樵夫哟,你掉的是这个免费 8 核 4G 公网服务器,还是这个随时可用的 Docker 实验平台?

newbe36524

Docker 微服务 .net core ASP.NET Core

我们是如何逐渐变普通的?

架构精进之路

个人成长 认知提升

技术分享丨数据仓库的建模与ETL实践技巧

华为云开发者联盟

数据仓库 数据分析 数据模型 GaussDB ETL算法

高并发,你真的了解吗?

华为云开发者联盟

负载均衡 软件 高并发 操作系统 服务器集群

面经手册 · 第5篇《看图说话,讲解2-3平衡树「红黑树的前身」》

小傅哥

Java 数据结构 小傅哥 红黑树 2-3树

架构到底是什么?

架构精进之路

架构

AI+云,数字金融掘金客户微细分

人称T客

5步教你完成小熊派开发板贴片

华为云开发者联盟

后端 开发工具 华为云 小熊派 开发板

昨梦记

波波夫

C++ 互斥锁和条件变量的性能比较

小林coding

c c++ 编程 并发编程

Docker 禁止美国“实体清单”主体使用,Docker 开源项目应不受影响

程序员生活志

Docker 互联网热点

面试官问:运行时的内存布局

Java小咖秀

Java JVM

了解JS压缩图片,这一篇就够了

华为云开发者联盟

Java html5 vue.js 大前端 npm

最受 IT 公司欢迎的 30 款开源软件

程序员生活志

开源

PHPStrom安装Xdebug及使用

书旅

php Xdebug PHPStrom

C++ 借来的资源,如何还的潇洒?

小林coding

c c++ 编程 编程习惯 内存管理

HTTP方式文件分片断点下载

xcbeyond

Java 断点续传 下载 Range

二叉树-四种遍历方式的 Java 实现

多选参数

二叉树 遍历

推荐一款可视化+NoteBook工具

数据社

大数据 可视化 Zeppelin notebook

MECE分析法

陈磊@Criss

测者陈磊

【得物技术】乘风破浪—优雅代码四部曲

得物技术

Java 代码规范

KPI考核存在的问题

石云升

读书笔记 考核 KPI 数字化管理

python操作word文件

wjchenge

Python word

对于一款软件而言,完备的功能固然重要,但交互体验也不该被忽视

Philips

Java 敏捷开发 UI .net core 交互设计

如何有效提高技能?我推荐《刻意练习》

老胡爱分享

个人成长 练习

一、GraphQL,你准备好了么?

星期35

学过 C++ 的你,你不得不知的这 10 条细节

小林coding

c c++ 编程 编程之路

实战分享丨MySQL 与Django版本匹配相关经验

华为云开发者联盟

MySQL 数据库 django 华为云

初识WebRTC

soolaugust

WebRTC

Sun的JDK7、OpenJDK及IcedTea释疑_Java_Dionysios G. synodinos_InfoQ精选文章