為什麼人們寧可用Lombok,也不把成員設為public?

語言: CN / TW / HK

大家好,我是哪吒。

思考一個問題,為何屬性是private,然後用get/set方法?

普遍想法

  1. 大家都這麼寫,我也這麼寫;
  2. 這是Java的封裝特性,你不知道?
  3. 隱藏屬性,不暴露過多細節,更安全;

下面系統的分析一下,why?

1、採用get/set方法其實是Java的一個協議,在1996年12月提出的java bean1.00-A,通過統一的規範可以設置對象的值(比如get、set方法)。很多框架也是在此基礎上開發的,底層源碼也都是通過get/set訪問屬性的。

2、很多時候,可以通過get/set方法,① 增加一些功能;② 增加一些特定的修改,比如打折;③ 增加一些訪問邏輯;④ 還可以通過set方法觸發一些事件。

3、如果你將一個屬性定義為public了,而且在50處調用了,此時,產品經理來了一個需求,將此次的促銷商品打五折;難道你要去修改這50處的代碼嗎?如果你用get/set封裝了,修改對應屬性的set方法即可,so easy~!

4、就像上面所説,大家都這麼寫,我也這麼寫,但是,對於大多數企業應用來説,直接將屬性寫成public,也是沒毛病。

5、也可以理解為,“風格統一的代碼更好維護”。

6、假如我新接手一個項目,要用到某個bean,我也不知道都有什麼屬性,一般的做法都是先new一個,然後通過小數點聯想出來,如果沒有get/set,那真的很煩躁。

7、現在都是面向接口編程,而Java接口中是不能定義普通的屬性的,但可以定義get/set方法。

來,一起回味一下封裝的概念。

封裝是指一個對象對其他對象隱藏其部分狀態和行為,而僅向程序其他部分暴露有限的接口的能力。封裝也叫作信息隱藏或者數據訪問保護。類通過暴露有限的訪問接口,授權外部僅能通過類提供的方式(或者叫函數)來訪問內部信息或者數據。對於封裝這個特性,我們需要編程語言本身提供一定的語法機制來支持。這個語法機制就是訪問權限控制。

Lombok應運而生

為了解決get/set的代碼臃腫問題,Lombok應運而生。簡單無腦,解決一切煩惱。

使用 Lombok 可以讓代碼更加簡潔,減少宂餘的代碼量。使用 Lombok 時,可以使用註解來生成常用的代碼,如 getter、setter、equals、hashCode 和 toString 方法,這些方法通常都是在 Java 類中需要手動編寫的。 使用 Lombok 可以省去這些手動編寫的步驟,使代碼更加簡潔。此外,使用 Lombok 還有一個好處是可以使用註解來生成構造函數和靜態構造函數,這些構造函數可以接受所有屬性作為參數。這樣就可以避免手動編寫很多構造函數的情況。因此,使用 Lombok 可以讓代碼更加簡潔,減少宂餘的代碼量,提高代碼的可讀性和可維護性。

Lombok代替public,因為public成員的可見性太大。將成員定義為public意味着任何地方都可以訪問這個成員,這可能會導致成員被意外地修改,從而影響類的穩定性和正確性。而使用Lombok可以通過自動生成getter和setter方法來保護成員的可見性,從而提高類的封裝性和可維護性。此外,使用Lombok還可以幫助開發人員減少編寫重複的代碼,提升工作效率。

因此,為了保護成員的可見性並提升代碼的可維護性,許多人寧可使用Lombok,也不願意將類的成員設為public。

不和諧的聲音,禁止使用Lombok?

1、jdk版本問題

目前國內大多數Java項目,採用的都是JDK1.8,因為它夠穩定,功能也完全夠用,但是,如果哪一天,你的客户心血來潮,就是想用JDK11,甚至JDK17,此時,你會發現Lombok不好用了,於是,不得不將好幾百個實體類,通過idea生成get/set、equals、toString等方法,很煩躁。

2、被迫營業

當你的客户獲取到你的源代碼之後,他也想看看,運行一下,此時發現沒安裝Lombok,報錯了,安裝Lombok,不瞭解這是什麼,還要去百度學習一下,被迫營業,很煩躁。

3、可讀性差
  1. Lombok隱藏了JavaBean的封裝細節;
  2. toString()不知道會打印什麼;
  3. @AllArgsConstructor提供一個全量構造器, 讓外界在初始化時,可以隨意修改其屬性,極其不安全。如果屬性過多,這個全量構造器,看起來,很雞肋;
  4. 參數的順序我們也無法控制,都是按照Lombok的心情來的;
4、使用Lombok,寫代碼的時候很爽,但它
  1. 污染了你的代碼;
  2. 玷污了Java語言的純粹;
  3. 破壞了Java代碼的完整性、可讀性、安全性;
  4. 增加了代碼的耦合度;
  5. 增加了代碼的調試難度;

這是一種弊大於利、得不償失的操作。

總結

綜上所述,將成員變量定義為public是不可取的,使用Lombok也不是一個明智的選擇,還是老老實實的通過IDE生成get/set方法吧。