为什么我喜欢Java

jopen 10年前

我现在的老板使用一个在线测试系统来筛选在线申请职位的求职者。测试的第一个问题很肤浅,仅仅是为了让求职者熟悉一下这个系统的提交和测试代码的流程。问题是这样的,写一个将标准输入拷贝到标准输出的流程。求职者可以使用任何他们喜欢的编程语言来实现这个程序。

有时候我们也会遇到在这个测试中得零分的求职者。当我看到他们连最肤浅的问题都答不出的成绩时,我的第一想法是,这并不反映出求职者有多差劲。很显然,这个测试系统本身太难使用才导致求职者甚至不能提交成功最简单的问题,所以失败归结于测试系统而不是求职者。

但是当我看求职者未提交成功的代码的时候,不止一次的(至少这一次)发现——不是测试系统的错。而是另一个甚至不会发生在我身上的问题:求职者提交失败是因为他们试图使用Java语言来实现这个程序。

我记起了Dijkstra的说法——“教授BASIC语言简直是在犯罪。”当看到求职者被Java搞的焦头烂额的时候,我在想是不是这个言论换成Java的话同样适用.

我不太确定,有可能还是这个测试系统的错;有可能Java程序员具备我们用的上的有价值的技能(抛开他们不能再很短的时间内解决一个肤浅问题不说的话)。我可能改变主意,就在这时,我感到担忧。

当你学习Perl, Python, Ruby, 或者 Javascript的时候,你学到的只是用哈希表解决问题的一些技术,这些仅仅称得上是语言的一部分。当你学Haskell时,就像是在学习一种用懒惰 的清单和单元来解决问题的技术。这些强大的多功能的工具是编程语言最重要的地方。

但是当你学习Java的时候,对于很多问题解决起来都没有强大的语言特点来供你使用。相反,你将会把时间花在用编程语言解决问题的技术上。Java 也有哈希表,但是从总体上来看,它们只不过是巨大的Collections库中的一种,和其他的种类淹没在Collections 的库中。而且也没有什么理由去了解并学习那些东西。优秀的Java课程可能倾向于分析Collections中有用的部分,但是,由于哈希表只是库的一部 分,所以很难看出跟AbstractAction或者zipOutputStream这种类比起来有什么重要的。

我是一个在不同的组织工作了3年的专业Java程序员。我的意思是有时候我会用Java语言来实现我的想法。我经常感到痛苦和刻薄,而且我也承认我 脾气暴躁,残酷,消极,所以对我来说,狂热的喜欢一件东西是很困难的。曾经我试图写一篇关于Blosxom的好文章,在2006年发布在我的博客上,最后 失败了;人们以为我是在进行批评,我不得不又写了个续篇来澄清,但是人们仍然认为我在批评Blosxom。因为这片文章对Java刻薄的批评让人困惑。我 必须声明:这篇文章中关于Java的一切内容都是持肯定态度的,并且也应该被接受。

我真的喜欢Java。

我很高兴能有有用Java编程的经历。我喜欢在Java编程主要因为我发现这个过程是很轻松的。如果使用一门不好的像是Fortran或者csh这 种编程语言的话,你会在每一件事上面苦苦挣扎,开发过程中还要不断同这门语言做斗争。使用好的编程语言却是完全不同的体验:利用语言的强大之处,使函数的 功能最大化,用最简洁的表达方式来实现代码。

Java既不是一门好的语言,也不是差得。算得上一门中等的语言,Java中没有挣扎。使用Haskell或Perl时你时常担心是不是应该用最简 洁、最高效的方式。在Java中就不必考虑这些,因为最简洁、最高效是不可能的。无论你做什么,怎样去努力,代码都会变得普通、繁琐、冗长、臃肿,你要做 的就是把握住方向,将这些重要的大篇代码从键盘中打出来如果最后的代码比用Haskell写的长十倍,也没有关系,因为IDE将会帮你处理掉一半,但是你 仍要为另一半付出代价。

所以你改变了心态,不管薪水如何了,也不再担心写出的代码是预先设计好的两倍之长有多么糟糕。你也许不能解决大型的问题,但是你可以参考一本书来解 决中等问题,这一行为又导致了更长的java代码,但是你仍能领到薪水。你是一个码农,你的工作就是写代码。你写了很多代码,所以你做好了自己的工作,每 个人都皆大欢喜。

你将不会做出任何绝妙的东西,但是同样,你也不会做出很糟糕的东西来。项目可能失败了,但你可以将失败归结于别的地方。毕竟,你用10000行代码 写了576个类,表面看来这些都是必不可少的,所以你做好了自己的本职工作。谁都不会责备你为什么要用576个类而不是50个,因为在Java里面仅仅用 50个类是不可能的。

(不同的语言有不同的失败模式。比如Perl,项目失败可能是因为你设计并实现了一堆废话,但是有一个万能的变通方案:你可以将项目继续下去,等它 变得足够大时交给别人,然后出错的话责任就会归咎于别人而不是你。在Haskell这么做的话,有可能在第一个月就被炒鱿鱼。)

所以是的,我喜欢用Java编程。这样可以从写高质量代码的责任中解脱出来。我很高兴不必担心我所做的是否优秀,或者我写的代码是否易读、易维护。代码变得臃肿,当然,这不是我的错。虽然一切都出于我手。

所以我喜欢Java。但是我不会选择这门语言来应对在线测试,除非分数靠代码的行数来评定。在测试中,你需要完成的快速,所以你需要优化代码来使它们简洁并且表达清楚。Java意味着很多东西,但从来和简洁、表达清楚无关。

当我看到可怜的求职者苦苦挣扎了15分钟14秒,试图用Java程序将标准输入拷贝到标准输出,最终放弃的时候,我为他们昂贵的教育感到悲哀,他们没有学会更好用的工具,或者除了在Java中受尽折磨的任何东西。

作者:Mark Dominus 译者:赖信涛 原文链接:Mark Dominus