把握行业变革关键节点,12 月 19 日 - 20 日,AICon北京站即将重磅启幕! 了解详情
写点什么

JRuby:该不该转向 Java 5?

  • 2007-07-30
  • 本文字数:1338 字

    阅读完需:约 4 分钟

jruby-dev 邮件列表中,一个关于向Java 5 迁移的讨论已经展开。早在Java 5 被引入之时,这就已经是对于Java 项目频繁讨论的话题了。有许多项目,例如Eclipse,选择尽可能久地保持对1.4 的兼容性,甚至有一些基本技术,例如OSGi 或者 SWT 还在保持对 1.1 和 1.2 的兼容性

独立应用程序在这方面问题则少了很多,尤其在它们的发行版附带了 JVM 的情况下更是如此。而在另一方面,类库则像个烫手山芋,因为向 Java 5 的迁移,从根本上意味着被强制部署在 Java 1.4 环境下的类库使用者将无法使用该类库,或者他们必须使用类库能够支持 Java 5 的较新版本。

JRuby 则处在独立应用程序和类库之间。毕竟,人们可以使用下面的一行命令来运行任意的 Ruby 程序:

jruby filename.rb对于这种情况,JRuby 需要某个特殊的 Java 版本并不会成为问题,除非 JRuby 中的特定代码需要 Java 5 类库。当然,如果公司在某个 Java 版本上进行了标准化的话,那么这就会成为一个问题了。

当 JRuby 被用在应用程序内部作为 Ruby 解析器的时候,它的身份也就变成了一个类库。在这种情况下,如果提高了 JRuby 所需的 Java 版本,也将迫使宿主应用不得不升级相应的需求(如果这些应用还没有使用 Java 5)。

除了允许 JRuby 团队使用诸如Annotation或者Enum这样的新语言特性以外,人们对打破与 1.4 的兼容性以及使用 Java 5 的新特性方面,还有一些相当有力的支持论据。其中之一就是在 Java 5 新增的高级并发类库。目前,JRuby 的分发包中还附带了用于早期Java 版本的 <strong>java.util.concurrent</strong>移植版类库,这就意味着下载大小的增加。此外,由于这个移植版无法使用 Java 5 中针对并发支持的类,它其中的某些功能无法和 Java 5 的java.util.concurrent系列类相匹敌的性能。

保持 1.4 版本兼容性的主要原因是大公司的升级周期一般都非常长,因此他们会试图在软件版本上进行标准化。然而,由于绝大多数平台都提供了 Java 5 的支持,当然也就是 Windows、MacOS X 和 Linux 的三重唱,因此反对向 Java 5 迁移的理由已经很快变得非常微不足道了。在 Java 5 发布了三年之后,有了早期采用者发现并报告问题之后,JVM 及其类库也已经可以很安全地被认为是成熟了的。

另外一个原因相比起来就不是那么重要了,即缺乏一个基于自由(文如其名)软件许可,与 Java 5 完全兼容的实现。尽管GNU Classpath以及Apache Harmony项目正在一步一步朝着完全兼容的目标挪进,但它们都还不到火候。实现95% 以上的API 完成度,已经是这些项目所取得的极大成功,但比起和Java 5 100% 兼容的目标,还仍显不足。尽管类似于Eclipse 这样的大型应用可以运行在开源JVM 之上,但仍有一些小的不兼容问题会随时跳将出来,也可能成为支持部门头上的一道金箍。

随着Sun 公司OpenJDK 项目的产生,一个完全以GPL 授权的Java 将会在不久的将来问世。(注意,Java 的其中一些部分还没有以GPL 的形式授权,因为Sun 还不具备将这些部分用GPL 授权的权力)。

应该提到的是,已经发布的JRuby 1.0 是兼容于Java 1.4 的,并且也将一如既往保持对1.4 的支持。

对此您又是什么样的想法呢?您是否还在从事需要保持1.4 兼容性项目的开发呢?如果是的话,在公司标准之外是否还有其它原因呢?

查看英文原文: JRuby: Java5 or not?

2007-07-30 01:001142
用户头像

发布了 117 篇内容, 共 20.9 次阅读, 收获喜欢 0 次。

关注

评论

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

企业级YashanDB权限控制和安全管理策略

数据库砖家

企业级YashanDB数据库迁移项目规划与风险控制

数据库砖家

企业数据合规性管理中YashanDB数据库的关键作用

数据库砖家

YashanDB 或优化其性能

数据库砖家

在企业数据平台中集成YashanDB数据库

数据库砖家

企业数据治理下的YashanDB合规性支持分析

数据库砖家

UUID 替代方案详解

俞凡

架构 算法

企业如何借助YashanDB数据库实现智能数据分析升级

数据库砖家

企业如何利用YashanDB数据库提升运营效率

数据库砖家

企业数据治理中YashanDB数据库的战略地位解析

数据库砖家

企业级YashanDB数据库的运维自动化实现路径

数据库砖家

企业级应用中YashanDB数据库的部署最佳实践

数据库砖家

企业如何利用YashanDB数据库实现数据驱动的决策体系

数据库砖家

企业数据规模扩展中YashanDB的弹性设计探索

数据库砖家

企业级YashanDB数据库容错机制实用指南

数据库砖家

GitLab沦为僵尸网络——共享Runner如何引发大规模DoS攻击

qife122

网络安全 云基础设施

企业级YashanDB数据库日志管理最佳实践

数据库砖家

企业级数据库选型:YashanDB的独特优势分析

数据库砖家

企业如何利用YashanDB数据库构建数据中台架构

数据库砖家

企业如何制定YashanDB数据库的安全审计流程

数据库砖家

工业管理 项目管理经验总结(16)

万里无云万里天

项目管理 工业 工厂运维

网站减碳实战指南:如何通过性能优化降低环境影响

qife122

网站优化 数字可持续性

企业如何评估YashanDB数据库项目实施的ROI

数据库砖家

企业如何通过YashanDB数据库实现智能监控体系

数据库砖家

企业使用YashanDB的成本优化策略及实践

数据库砖家

企业数据治理中YashanDB数据库的核心作用剖析

数据库砖家

绕过Cloudflare IP白名单限制的技术解析

qife122

网络安全 Cloudflare 漏洞绕过

企业级YashanDB数据库应用架构设计最佳实践指南

数据库砖家

企业在将数据迁移到YashanDB

数据库砖家

企业级YashanDB数据库容量规划的实用经验分享

数据库砖家

企业数据架构优化,YashanDB的实用部署指南

数据库砖家

JRuby:该不该转向Java 5?_Java_Werner Schuster_InfoQ精选文章