【代碼修鍊系列分享】改掉這些壞習慣,還怕寫不出健壯的代碼?(一)

Code Review 是一場苦澀但有意思的修行。

近期對團隊負責的項目,進行了一次 Code Review,代碼評審過程中遇到的那些編碼壞習慣,笑的合不攏嘴。不過,評審中很多代碼編寫問題,以往都多次提及過,所以還是按奈不住心中怒氣的小火苗。

作為用代碼編寫人生的程序員,能擁有寫一手健壯代碼的本領,那絕對很有必要。因為健壯的代碼能夠把 Bug 扼殺在搖籃里,能夠讓問題止步於上線前。

那麼,怎樣才能練就寫出健壯代碼的本領呢?

本次着重談談那些代碼編寫時的一些壞習慣,改掉這些壞習慣,相信會向健壯代碼邁進一大步。

一、編碼時易忽略性能的壞習慣 

壞習慣一:調用低效的構造器,創建包裝類型的對象

反例:

正解:

解惑:使用 Long.valueOf(long) 代替 new Long(long),可以提高性能。

如 Long 源碼所示,如果當傳入的值介於 -128~127 時,會優先從緩存中返回緩存的值,而不是進行 new,充分利用空間換取時間,所以當值介於 -128~127 時,採取 Long.valueOf(long) 的效率要比 new Long(long) 快很多。

建議:

  • 凡是涉及到 Long, Integer, Short, Character 以及 Byte 創建對象時,優先採用高效的 valueOf() 方法,而不是直接用低效構造器創建實例。
  • 享元設計模式在這兒用到了,什麼是享元模式?(留個作業)

壞習慣二:使用 keySet 迭代器迭代 Map,獲取對應的 value。

反例:

正解:

解惑:keySet 方式遍歷 Map 的性能不如 entrySet 性能好。

如果採用 keySet 的方式獲取 Map 中 key,然後通過 key 獲取 Map 對應的 value,如上圖 HashMap 源碼所示,每次都需要通過 key 去計算對應的 hash 值,然後再通過 hash 值獲取對應的 value,效率會低不少。

建議:

  • 如果想獲取 Map 對應的 key 和 value,則推薦使用 entrySet。
  • 如果只是單純獲取 Map 對應的 key,則推薦使用 keySet。

壞習慣三:使用 new Date().getTime() 獲取當前時間戳。

反例:

正解:

解惑:如下圖 Date 源碼所示,Date 構造方法中最終還是調用了 System.currentTimeMillis() 方法來獲取時間戳。

建議:

  • 獲取當前毫秒數採用 System.currentTimeMillis(),而不是new Date().getTime(); 
  • 獲取更加精確的納秒級時間值,採用 System.nanoTime;
  • 在 JDK8 中,針對統計時間等場景,建議使用 Instant 類。

壞習慣四:循環中使用 ”+“ 號拼接字符串。

反例:

正解:推薦使用 StringBuilder/StringBuffer 進行字符串拼接。

解惑:「Java 程序該怎麼優化?技巧篇」以前的這篇分享做過試驗,本次不贅述。

二、編碼時易犯的一些小毛病 

毛病一:變量作為 equals() 方法的調用方。

反例:

正解:

解惑:totalCount 應該作為方法  equals() 的調用方,而不是參數 作為調用方,因為參數作為調用方會出現空指針異常。

建議:

  • 字符串的比較,常量建議當做 equals() 方法的調用方;
  • 字符串判斷空,建議用項目中的工具類。

毛病二:對象為 null 的檢查滯后。

反例:

正解:請在使用 data 對象前,做好是否為 null 的判斷。

解惑:後置對象為空的檢查,可能會導致空指針異常的發生。

毛病三:要求傳入非空的方法,傳入空值。

反例:

正解:signInfo 變量的值可能存在為空的情形,導致發生空指針異常。

建議:發生異常的時候,方法該終止就終止;盡量做好防禦性編程,該校驗的參數進行必要的校驗。

三、寄語寫最後 

常在河邊站哪有不濕鞋,再牛逼的碼農,編碼也會有失誤的時候,很有必要藉助一款代碼檢查工具,做最後一道防線。

在這裏,推薦 FindBugs、Checkstyle、SonarQube 三款代碼檢查工具,不過我用的最多的當屬 FindBugs,可以拿去一試,使用門檻幾乎為零。

好了,編碼中易犯的那些臭毛病,本次就談到這裏,不知道有多少條是觸動了你的心弦,希望有則改之。

關注同名公眾號:一猿小講,回復「1024」可以獲取精心為您準備的職場打怪進階資料。

一起聊技術、談業務、噴架構,少走彎路,不踩大坑,會持續輸出原創精彩分享,敬請期待!

本站聲明:網站內容來源於博客園,如有侵權,請聯繫我們,我們將及時處理

【其他文章推薦】

※廣告預算用在刀口上,台北網頁設計公司幫您達到更多曝光效益

新北清潔公司,居家、辦公、裝潢細清專業服務

※別再煩惱如何寫文案,掌握八大原則!

※教你寫出一流的銷售文案?

※超省錢租車方案

您可能也會喜歡…