CTO:再寫if-else,逮著罰款1000!
來自公眾號:51CTO技術(shù)棧
作者:Nicklas Millard,在丹麥的四大咨詢公司之一中擔(dān)任高級技術(shù)顧問,主要擔(dān)任客戶項目的首席開發(fā)人員和解決方案架構(gòu)師。
編輯:陶家龍
出處:https://medium.com/swlh/5-ways-to-replace-if-else-statements-857c0ff19357
本文并不肯定或者否定哪一種寫法,僅僅為大家提供一些其他的編碼思路或者一些值得借鑒的點子。

設(shè)計更好的軟件,替換 If-Else 的 5 種方法,從入門到高級示例
If-Else 通常是一個糟糕的選擇,它導(dǎo)致設(shè)計復(fù)雜,代碼可讀性差,并且可能導(dǎo)致重構(gòu)困難。
但是,If-Else 已成為事實上的代碼分支解決方案,這確實是有道理的。這是向所有有抱負(fù)的開發(fā)人員講授的第一件事。
不幸的是,許多開發(fā)人員從來沒有前進到更合適的分支策略。有些人的口頭禪是:If-Else 是一把錘子,一切都是釘子。
我將向大家展示一些技巧和模式,這些技巧和模式將終結(jié)這種可怕的做法。每個示例的難度都會增加。
完全不必要的 Else 塊
這也許是那些初級開發(fā)人員最負(fù)罪的之一。下面的示例很好地說明了當(dāng)你被認(rèn)為 If-Else 很棒時會發(fā)生什么:

Simple if-else

Removed else
看起來更專業(yè)吧?你會發(fā)現(xiàn),實際上根本不需要其他塊。像在這種情況下一樣,你想要在滿足特定條件的情況下執(zhí)行某些操作并立即返回。
價值分配

Value assignment with if-else

If statements with fast return
如果不使用 else,則我們將剩下干凈的可讀代碼。請注意,我也將樣式更改為快速返回而不是單返回語句。如果已經(jīng)找到正確的值,繼續(xù)測試一個值根本沒有意義。
前提條件檢查

Method without value checks
在沒有價值驗證的情況下執(zhí)行該方法沒有任何意義。因此,在允許方法繼續(xù)執(zhí)行之前,我們需要檢查一些先決條件。

Check preconditions with guard clauses
至此,我們確保僅在值落在預(yù)期范圍內(nèi)時才執(zhí)行主邏輯。現(xiàn)在,IF 也已被三元代替,因為不再需要在結(jié)尾處默認(rèn)返回"未知"。
將 If-Else 轉(zhuǎn)換為字典,完全避免 If-Else

也許有人傾向于使用久經(jīng)考驗的 If-Else。如果添加新操作,則只需簡單地添加其他內(nèi)容即可。很簡單 但是,就維護而言,這種方法不是一個好的設(shè)計。

可讀性已大大提高,并且可以更輕松地推斷出該代碼。注意,僅出于說明目的將字典放置在方法內(nèi)部。您可能希望從其他地方提供它。
擴展應(yīng)用程序,完全避免使用 If-Else
這是一個稍微高級的示例。通過用對象替換它們,知道何時甚至完全消除 If。
通常,您會發(fā)現(xiàn)自己不得不擴展應(yīng)用程序的某些部分。作為初級開發(fā)人員,您可能會傾向于通過添加額外的 If-Else(即 else-if)語句來做到這一點。
舉這個說明性的例子。在這里,我們需要將 Order 實例顯示為字符串。首先,我們只有兩種字符串表示形式:JSON 和純文本。

知道我們需要擴展應(yīng)用程序的這一部分,這種方法絕對是不可接受的。
上面的代碼不僅違反了"打開/關(guān)閉"原則,而且閱讀得不好,還會引起可維護性方面的麻煩。
正確的方法是遵循 SOLID 原則的方法,我們通過實施動態(tài)類型發(fā)現(xiàn)過程(在本例中為策略模式)來做到這一點。
重構(gòu)這個混亂的過程的過程如下:
使用公共接口將每個分支提取到單獨的策略類中。
動態(tài)查找實現(xiàn)通用接口的所有類。
根據(jù)輸入決定執(zhí)行哪種策略。
替換上面示例的代碼如下所示。是的,這是更多代碼的方式。它要求您了解類型發(fā)現(xiàn)的工作原理。但是動態(tài)擴展應(yīng)用程序是一個高級主題。

讓我們快速瀏覽一下代碼。方法簽名保持不變,因為調(diào)用者不需要了解我們的重構(gòu)。
首先,獲取實現(xiàn)通用接口 IOrderOutputStrategy 的程序集中的所有類型。然后,我們建立一個字典,格式化程序的 displayName 的名稱為 key,類型為 value。
然后從字典中選擇格式化程序類型,然后嘗試實例化策略對象。最后,調(diào)用策略對象的 ConvertOrderToString。
推薦閱讀:
完全整理 | 365篇高質(zhì)技術(shù)文章目錄整理
專注服務(wù)器后臺技術(shù)棧知識總結(jié)分享
歡迎關(guān)注交流共同進步
