对Ruby VS Java误区的深度剖析 - 编程入门网
对Ruby VS Java误区的深度剖析时间:2011-11-20Relevance咨询公司的Stuart Halloway最近编写了一个关于“Ruby vs. Java之怪谈”的系列博客文章 。这个系列文章的灵感,源自他最近从一个从零起步、没有先前约束的Ruby项目转回一个成熟完备的Java 项目后的心得体会。在这个历时多日的项目过程中,Halloway对以下几个“误区”进行了探索: 误区之一:Ruby适合小型项目,而Java更适用于大型的、复杂的项目。 概括起来,Halloway主张,对于小型项目来说,诸如未知因素一类的问题可能会使进度表大幅度改动 ,而如果找到一个成熟完善的代码库则可以使得开发人员几乎不用编写多少代码。在 Java方面,这些因 素是很大的一个优势,因为它背后有一个成熟强大的社区和一群非常有经验的开发人员所支持。对于大型 项目,Halloway则称,诸如语言的生产效率之类的因素会比代码库更为紧要,这也把天平上优势的砝码放 在了Ruby一端。他指出,目前事实已经发生逆转,并解释说: 以下是引用片段: 当前Ruby异常适合的一种小型项目是:由数据库所支撑的Web应用,因为RubyonRails抵消掉了所有Ruby在 小型项目方面的不利因素。 误区之二:Ruby的某某特性使得代码难以维护 针对这个认识误区,Halloway的结论是:如果使用得当,Ruby的语言特性会使用其编写的代码更加易 于维护。对于“易于维护的代码”的概念,他给出以下定义: 1. 理解应用程序或者模块的总体设计思路 2. 找到你所需要的代码 3. 阅读代码 4. 对代码进行变更 5. 检查变更是否正常运行 对Ruby VS Java误区的深度剖析(2)时间:2011-11-20下面是两种语言的优势对比: 理解应用程序或者模块的总体设计思路:无一胜出 以下是引用片段: [...]我的经验表明,在这个方面没有哪个语言能帮上很多忙,但良好的抽象概念会有所帮助。Java和 Ruby包含很多相同的抽象概念:实现继承、类、多态和封装等等。 查看你所需要的代码:Java胜出 由于IDE的有效支持,Java在这个方面胜出。 阅读代码:Ruby胜出 结论:Ruby代码更容易保持DRY原则,因此更容易阅读。 对代码进行变更:Ruby胜出 结论:在动态语言中进行代码变更更为容易。 检查变更是否正常运行:不相伯仲 Ruby和Java都提供了对单元测试、验收测试和持续集成等方面的良好支持。 误区之三:Ruby太难了 有些人,比如Cedric Beust主张说,对于普通开发人员Ruby的难度太大。Halloway反驳到,总的来说 ,编程就不是一件容易的事情。尽管有些丛书以“21天学会编程”的旗号为噱头,但这是不可能的。因此 ,使用Java和Ruby编程都不是一件容易的事情。他主张说: 以下是引用片段: [...]你不能通过限制语言的特性这种方式来降低难度[...] 对Ruby VS Java误区的深度剖析(3)时间:2011-11-20误区之四:要抄袭Rails的创意很容易 Halloway提出,这个误区需要慎重看待,因为它说的确实有一部分是真的。Rails的许多创意是可以被 抄袭到其它任何语言上去的。但是,对于这个观点的反驳也存在: 以下是引用片段: [...]另外一些创意则取决于特定的Ruby语言特性。Rails使用了openclass,使得我们可以写出更好的 、可读性更强的对象模型。举例而言,你可以写出x.blank?这样的代码,而不是这样: StringUtilities.isBlank(x)。单独来说,这样的区别并不会产生很大的意义,但是随着它们积少成多了 以后,代码的可读性就会得到显著的提升。[...] 误区之五:这是一场没有赢家的游戏 最后是系列文章的总结陈词:作为一门语言,Ruby胜出;但作为一个平台,Java胜出—— 以下是引用片段: 那么,我们所有人难道不能和睦相处么?我多希望在我所生活的世界中,对语言的偏好并不会给一名程序 员贴上什么标签。我们可以用Ruby、Scheme、Scala或者Erlang来编写代码,而且任何地方的JVM都是我们 所可以生存的和谐社会。 为了让这样的和谐氛围得以延续,Halloway对应当采取的行动给出了以下建议:为JRuby项目贡献代码 ,并在今后的Java应用中使用Rake而不是Ant来管理。 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |