写点什么

对Ruby vs. Java误区的深度剖析

2007 年 6 月 21 日

Relevance 咨询公司的 Stuart Halloway 最近编写了一个关于“Ruby vs. Java 之怪谈”的系列博客文章。这个系列文章的灵感,源自他最近从一个从零起步、没有先前约束的 Ruby 项目转回一个成熟完备的 Java 项目后的心得体会。在这个历时多日的项目过程中,Halloway 对以下几个“误区”进行了探索:

误区之一:Ruby 适合小型项目,而 Java 更适用于大型的、复杂的项目。

概括起来, Halloway 主张,对于小型项目来说,诸如未知因素一类的问题可能会使进度表大幅度改动,而如果找到一个成熟完善的代码库则可以使得开发人员几乎不用编写多少代码。在 Java 方面,这些因素是很大的一个优势,因为它背后有一个成熟强大的社区和一群非常有经验的开发人员所支持。对于大型项目,Halloway 则称,诸如语言的生产效率之类的因素会比代码库更为紧要,这也把天平上优势的砝码放在了 Ruby 一端。他指出,目前事实已经发生逆转,并解释说:

当前 Ruby 异常适合的一种小型项目是:由数据库所支撑的 Web 应用,因为 Ruby on Rails 抵消掉了所有 Ruby 在小型项目方面的不利因素。

误区之二:Ruby 的某某特性使得代码难以维护

针对这个认识误区,Halloway 的结论是:如果使用得当,Ruby 的语言特性会使用其编写的代码更加易于维护。对于“易于维护的代码”的概念,他给出以下定义:

  1. 理解应用程序或者模块的总体设计思路
  2. 找到你所需要的代码
  3. 阅读代码
  4. 对代码进行变更
  5. 检查变更是否正常运行

下面是两种语言的优势对比:

理解应用程序或者模块的总体设计思路:无一胜出

[…] 我的经验表明,在这个方面没有哪个语言能帮上很多忙,但良好的抽象概念会有所帮助。Java 和 Ruby 包含很多相同的抽象概念:实现继承、类、多态和封装等等。

查看你所需要的代码:Java 胜出
由于 IDE 的有效支持,Java 在这个方面胜出。

阅读代码:Ruby 胜出
结论:Ruby 代码更容易保持 DRY 原则,因此更容易阅读。

对代码进行变更:Ruby 胜出
结论:在动态语言中进行代码变更更为容易。

检查变更是否正常运行:不相伯仲
Ruby 和 Java 都提供了对单元测试、验收测试和持续集成等方面的良好支持。

误区之三:Ruby 太难了

有些人,比如 Cedric Beust 主张说,对于普通开发人员 Ruby 的难度太大。Halloway反驳到,总的来说,编程就不是一件容易的事情。尽管有些丛书以“21 天学会编程”的旗号为噱头,但这是不可能的。因此,使用 Java 和 Ruby 编程都不是一件容易的事情。他主张说:

[…] 你不能通过限制语言的特性这种方式来降低难度 […]

误区之四:要抄袭 Rails 的创意很容易

Halloway 提出,这个误区需要慎重看待,因为它说的确实有一部分是真的。Rails 的许多创意是可以被抄袭到其它任何语言上去的。但是,对于这个观点的反驳也存在:

[…] 另外一些创意则取决于特定的 Ruby 语言特性。Rails 使用了 open class,使得我们可以写出更好的、可读性更强的对象模型。举例而言,你可以写出x.blank?这样的代码,而不是这样:StringUtilities.isBlank(x)。单独来说,这样的区别并不会产生很大的意义,但是随着它们积少成多了以后,代码的可读性就会得到显著的提升。[…]

误区之五:这是一场没有赢家的游戏

最后是系列文章的总结陈词:作为一门语言,Ruby 胜出;但作为一个平台,Java 胜出——

那么,我们所有人难道不能和睦相处么?我多希望在我所生活的世界中,对语言的偏好并不会给一名程序员贴上什么标签。我们可以用 Ruby、Scheme、Scala 或者 Erlang 来编写代码,而且任何地方的 JVM 都是我们所可以生存的和谐社会。

为了让这样的和谐氛围得以延续,Halloway 对应当采取的行动给出了以下建议:为 JRuby 项目贡献代码,并在今后的 Java 应用中使用 Rake 而不是 Ant 来管理。

查看英文原文: Digging Deeper Into The Myths of Ruby vs. Java

2007 年 6 月 21 日 01:30456
用户头像

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

关注

评论

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

深度解读 Flink 1.11:流批一体 Hive 数仓

Apache Flink

大数据 flink 流计算 实时计算 大数据处理

产品经理的商业能力

夜来妖

程序人生 产品经理 商业 商业模式 商业价值

架构学习历程

机器学习算法评估指标——2D目标检测

做技术BP的文案Gou

Python 自动化办公之"你还在手动操作“文件”或“文件夹”吗?"

JackTian

Python 自动化

杂谈-JSONP探索

卡尔

Java jsonp

从 0 到 1 搭建技术中台之发布系统实践:集泳道、灰度、四端和多区域于一体的设计与权衡

伴鱼技术团队

架构 系统设计 系统架构 系统性思考 架构设计

这些Java8官方挖的坑,你踩过几个?

码大叔

Java 踩坑 加密 「Java 25周年」

不想被下载限速,教你自建属于自己的云盘!

小傅哥

小傅哥 云服务 云盘 在线网盘

Vue生态篇(二)

shirley

Vue

游戏夜读 | 2020周记(5.24-5.31)

game1night

一个人,沿着童年的路究竟可以走多远?

zhoo299

童年 NASA 航天

从技术到管理,我在极客时间的成长历程

邓建春

【求锤得锤的故事】Redis锁从面试连环炮聊到神仙打架。

why技术

redis 分布式锁 分布式系统

赢的境界 - 双赢思维

石云升

创业 创业心态 双赢思维

互联网时代的界限管理

非著名程序员

程序员 职场 提升认知 界限管理

这是一个测试文档

Geek_073cad

我的 windows 利器

玄兴梦影

工具

MySQL实战笔记-事务隔离和MVCC

shiziwen

MySQL 学习 事务隔离级别

信息的表示与存储-整数的表示

引花眠

情绪的力量:如何使用情绪来达成目标

七镜花园-董一凡

情绪

Linux 自动化运维工具 ansible

杨仪军

Linux 运维自动化

[Redis] 你了解 Redis 的三种集群模式吗?

猴哥一一 cium

redis redis高可用 redis哨兵模式 群集安装

ARTS打卡 第2周

引花眠

ARTS 打卡计划

匆忙的一周 ARTS第二周

困到清醒

程序员修炼的务实哲学

博文视点Broadview

程序员 软件 编程思维 工程师 编程之路

Redis持久化了解一波!

不才陈某

redis 程序员 后端

关于区块链的“去中心化”,90% 的人都搞错了

CECBC区块链专委会

CECBC 区块链技术 去中心化 专制

java的时间利器:joda

毛佳伟🐳

Java

坏的开始是成功的一半

escray

原创 | 使用JUnit、AssertJ和Mockito编写单元测试和实践TDD (十三)编写测试-生命周期方法

编程道与术

Java 编程 TDD 单元测试 JUnit

对Ruby vs. Java误区的深度剖析-InfoQ