你以為這樣寫Java程式碼很6,但我看不懂

沉默王二發表於2020-04-14

為了提高 Java 程式設計的技藝,我最近在 GitHub 上學習一些高手編寫的程式碼。下面這一行程式碼(出自大牛之手)據說可以征服你的朋友,讓他們覺得你寫的程式碼很 6,來欣賞一下吧。

IntStream.range(1, 5).boxed().map(i -> { System.out.print("Happy Birthday "); if (i == 3) return "dear NAME"; else return "to You"; }).forEach(System.out::println);

我雖然擁有 10 年的 Java 程式設計經驗,但說實話,很慚愧,這段程式碼就好像一塊板磚拍在我腦袋上,有點懵逼。Lambda 表示式我是學過的,Stream 流我是學過的,forEach() 方法我也是學過的,但把這些知識點全部塞到一行程式碼中,我還是有點消化不良。

我總覺得這行程式碼不如換成老式的語法(Java 7 之前)來寫,就像下面這樣:

for (int i = 1; i < 5; i++) {
    System.out.println("Happy Birthday " + (i == 3 ? "dear NAME" : "to you"));
}

哇,beautiful code,簡潔又明瞭!不僅我能看得懂,就連剛入門的 Java 小白都能看得懂。要知道,程式碼是寫給人看的,假如只有自己看得懂,只有自己覺得很 6,而其他人看起來雲裡霧裡的,就不一定是好程式碼,儘管好像是行走在技術的前沿。

俗話說得好,“能力越大,責任越大”。Java 8 為我們提供了強大的能力,它的新特性是劃時代的(Java 8 之後的版本中新特性都不夠亮眼),包括 Lambda 表示式和 Stream 流,我們通過它們可以寫出簡潔又高效的程式碼。打個不恰當的比喻,Java 8 之前,開發者駕駛的是桑塔納,Java 8 之後,開發者駕駛的是法拉利。

但如果駕駛技術不好的話,法拉利也能變成桑塔納,甚至還不如。拿之前那段看起來似乎很 6 的程式碼來說吧,它並不是一段好的程式碼——儘管使用了新穎的技術,但難以理解。

在 Java 8 之前,如果你想編寫函式式程式碼的話,應該會使用 Google 的 Guava 類庫,它是一個很棒的開源類庫(不陌生吧),可以在一定程度上彌補 Java 原生類庫的不足。我在它的 wiki 上看到下面這樣一條建議,說得很富有遠見:

Excessive use of Guava’s functional programming idioms can lead to verbose, confusing, unreadable and inefficient code. … when you go to preposterous lengths to make your code “a one-line”, the Guava team weeps.

應該能看得懂吧?大致的意思就是說,如果過度使用 Guava 的函數語言程式設計的話,會導致程式碼冗長、混亂、不可讀,甚至低效;如果有些開發者為了減少程式碼的長度,刻意把多行程式碼“優化”成一行程式碼時,Guava 甚至會被玩哭。

我只能說,優秀的人真可怕,他不僅知道自己的長處,更瞭解自己的不足——說的就是你,Guava 的開發者。至於開頭提到的那位大牛,他寫的程式碼我就不敢恭維,只能說炫技炫到盲目自信吧。根據我的經驗,只有很少一部分的大牛能夠保持理智,在追求技術創新的同時意識到炫技的問題。

我認為,Guava wiki 上的建議同樣適用於 Java 8,好技術要妥善的利用,而不是濫用。眾所周知,Java 8 的新特性可以用來減少冗餘程式碼,當我們把一個複雜的匿名內部類變成一個簡潔的 Lambda 表示式就是一個很好的例子。

Thread t1 = new Thread(new Runnable() {
    @Override
    public void run() {
        System.out.println("匿名內部類,搞起來");
    }
});
t1.start();

// 優化後

Thread t2 = new Thread(() -> {
    System.out.println("Lambda 表示式,搞起來");
});
t2.start();

你看,優化後的程式碼量更少,並且一目瞭然,任誰也不會搞到看不懂的地步。函數語言程式設計出現的目的可不僅僅是為了減少冗餘程式碼,它是為了解放生產力——言外之意就是說,程式碼複雜點沒關係,只要可用可靠。程式設計的目標不是產生儘可能少的程式碼,而是產生易於維護的、高效能的系統。

舉個例子來說,假如我從洛陽出發,去鄭州參加一個技術沙龍,我就沒必要坐飛機;高鐵和駕車才是最優的選擇。明白我說的意思吧?別整那些花裡胡哨的,實用至上。

好了,我親愛的讀者朋友,以上就是本文的全部內容了,能看到這裡的就是最優秀的程式設計師。原創不易,❤️ 不要忘記留下你學習的腳印 [點贊 + 收藏 + 評論]

如果覺得文章對你有點幫助,請微信搜尋「 沉默王二 」第一時間閱讀,回覆【666】【1024】更有我為你精心準備的 500G 高清教學視訊(已分門別類),以及大廠技術牛人整理的面經一份,本文原始碼已收錄在碼雲傳送門~

相關文章