Java程序員的錯
Java 程序員是有問題的。我使用 Java 編程已經(jīng)有 10 多年的歷史。同時,我還有過大量的使用其它語言開發(fā)的經(jīng)歷,比如C#, C, C++, Python, Lua, Objective-C 等等,我認為這些經(jīng)歷在對我認識 Java 程序員的問題上起到了巨大的幫助。很多人說 Java 是一種很糟糕的編程語言。我不同意。Java 語言有它自己的缺點,但我想,很多時候,當你看到 Java 在有些地方讓人很多人不爽時,那本質(zhì)上不是 Java 語言的問題,而是它被錯誤的使用。
這些年來,在我見過的各種 Java 代碼中,我發(fā)現(xiàn)這***的問題是,寫代碼的人癡迷于把自己當作架構(gòu)師。他們很喜歡這樣,在我閱讀他們的代碼時,經(jīng)常會發(fā)現(xiàn)這些代碼與其說是去真正的解決一個問題,事實上更像是為了解決一個問題而規(guī)劃的一個藍圖模板。這兩者之間并不是細微的差別。你會看到繼承很深的抽象層和成堆臃腫的樣板式的代碼。由面向?qū)ο蠖Q生的子類超生現(xiàn)象無以復(fù)加。你根本無法一眼看明白、理解這些代碼是干什么的——你需要一層層深入挖掘,你需要理解它的整套濫用的術(shù)語和折磨人的詞匯(“AbstractAdapterFactory”),你必須要把自己當成系統(tǒng)的一部分。我已經(jīng)記不起來上一次看到一個不是這種情況的 Java 項目是什么時候了。
導(dǎo)致在 Java 王國里代碼最終總會變成這樣的原因有很多。Java 語言自身要承擔一定責任。Java 平臺的 API 就是上面說的這些問題的典范,于是,善良的程序員們沿襲標準類庫里體現(xiàn)出來的編碼規(guī)范和風格,將之當作通用的好的編程原則,一下子就誤入迷途。Java 語言還會對程序員強迫施加一種上層的形式主義和啰嗦,以至于***你不得不習慣了這樣的風格,當看到其它語言的簡潔語法時,反而感覺就像它們都是沒穿衣服的裸體——這就是“斯德哥爾摩綜合癥”(譯注:來源于 1973 年發(fā)生于此地的一次銀行搶劫案中,一個人質(zhì)浪漫地被她的劫持者吸引住了)。
面向?qū)ο蟮牧餍胁糠衷蛞彩沁@種心理作用造成的。有越來越多的程序員開始退后一步用整體的眼光認識 Java,他們發(fā)現(xiàn),作為一種編程模式,面向?qū)ο笳娴氖窍喈數(shù)脑愀?。然而,Java 是***限度的根植于面向?qū)ο竽J?,如果沒有面向?qū)ο?,Java 寸步難行。即使是今天,你仍然能看到大學里的編程課程嚴重的偏向面向?qū)ο?,大量的使?Java 授課,相比起 10 年前、5 年前要普遍的多。
雖然 Java 語言非常的流行,在企業(yè)軟件開發(fā)里被普遍的采用,但這一點都無助于 Java 編程質(zhì)量的提高。我坦白的說,你在各種企業(yè)產(chǎn)品里看到的大量的 Java 代碼都是由非常低質(zhì)量的程序員寫出來的。
非常糟糕的是,這些問題并不是只體現(xiàn)在代碼上,而是在整個 Java 生態(tài)系統(tǒng)上也是如此。不論是你使用的 Java 單元測試工具、依賴關(guān)系管理工具,還是模擬框架,即使是很小的 Java 程序,你也逃離不了它周邊龐大的系統(tǒng)。Java 程序員無能為力——讓他們開發(fā)一個小功能,你必然會看到一個繼承 15 層的類工廠(factory)的出現(xiàn)。
今天,我在學習 Gradle 框架,很顯然是因為最近它在 Android 開發(fā)社群里很火。Gradle 來自于 Java 世界,所以它繼承了上面我說的所有的 Java 所具有的問題。正像 Tim Bray 最近抱怨的:
“我的瀏覽器打開的是 Gradle 文檔的一頁:第 50 章.依賴關(guān)系管理。它有 63 個小章節(jié),劃歸在 10 個一級章節(jié)下,這是第 50 章,文檔一共有 65 章(包括五節(jié)附錄)。”
Android——如果說除了那些開發(fā)企業(yè)軟件的人,還有人會在意 Java,那一定是因為它——它沿襲 Java 的老路,走的更遠。你會習以為常的發(fā)現(xiàn),在讀一頁 Android API 文檔時,你根本不知道它究竟是在說什么。當然,最終你會弄明白,你需要繞道弄清楚其它 17 個類才行。什么?這讓你吃不消?你顯然不具備學習 Java 系統(tǒng) API 的百折不撓的精神。你會變成一個 Loser。
谷歌公司里開發(fā) Android 的工程師忙于構(gòu)筑偉大的系統(tǒng)框架,沒有時間解決真正的問題。
我是一個 Android 程序員,我討厭 Java。它讓我很受傷。
英文原文:Java Developers