有没有令人信服的理由不使用Groovy?
在长期缺席该平台之后,我正在用Java开发一个LoB应用程序(在过去的8年左右的时间里,我在Fortran,C,一小部分C++和后来的.Net中根深蒂固)。
Java,这门语言,与我记忆中没有太大变化。我喜欢它的优点,我可以解决它的缺点 - 平台已经成长,决定无数不同的框架,这些框架似乎彼此做同样的事情是一个不同的故事;但这可以等到另一天 - 总而言之,我对Java感到满意。然而,在过去的几周里,我对Groovy着迷,纯粹是从自私的角度来看:但不仅仅是因为它使针对JVM的开发成为比Java(语言)更简洁,更有趣(以及“时髦”)的命题。
Groovy最让我印象深刻的是它固有的可维护性。我们所有人(我希望!)都努力编写出文档良好,易于理解的代码。但是,有时我们使用的语言本身会打败我们。例如:在 2001 年,我用 C 语言编写了一个库,用于将 EDIFACT EDI 消息转换为 ANSI X12 消息。这不是一个特别复杂的过程,如果稍微涉及的话,我认为当时我已经正确地记录了代码 - 我可能已经这样做了 - 但是大约六年后,当我重新审视该项目时(并且在适应C#之后),我发现自己迷失在如此多的C样板(mallocs,指针等)中,以至于我花了三天的深思熟虑的分析才终于明白我六年前一直在做什么。
今天晚上,我写了大约2000行Java(毕竟这是休息日!我已经尽我所能地记录了如何,但是,但是,在这2000行Java中,很大一部分是Java样板。
这就是我看到Groovy和其他动态语言获胜的地方 - 可维护性和后来的理解。Groovy可以让您专注于自己的意图,而不会陷入特定于平台的实现的困境;它几乎是,但不完全是自我记录。我认为,当我在几年后重新审视我目前的项目(我将尽快将其移植到Groovy)时,这对我和我的继任者来说都是一个巨大的福音,他们将继承它并继续良好的工作。
那么,有什么理由不使用Groovy呢?