本文并不肯定或者否定哪一種寫(xiě)法,僅僅為大家提供一些其他的編碼思路或者一些值得借鑒的點(diǎn)子。
設(shè)計(jì)更好的軟件,替換 If-Else 的 5 種方法,從入門(mén)到高級(jí)示例
If-Else 通常是一個(gè)糟糕的選擇,它導(dǎo)致設(shè)計(jì)復(fù)雜,代碼可讀性差,并且可能導(dǎo)致重構(gòu)困難。
但是,If-Else 已成為事實(shí)上的代碼分支解決方案,這確實(shí)是有道理的。這是向所有有抱負(fù)的開(kāi)發(fā)人員講授的第一件事。
不幸的是,許多開(kāi)發(fā)人員從來(lái)沒(méi)有前進(jìn)到更合適的分支策略。有些人的口頭禪是:If-Else 是一把錘子,一切都是釘子。
我將向大家展示一些技巧和模式,這些技巧和模式將終結(jié)這種可怕的做法。每個(gè)示例的難度都會(huì)增加。
完全不必要的 Else 塊
這也許是那些初級(jí)開(kāi)發(fā)人員最負(fù)罪的之一。下面的示例很好地說(shuō)明了當(dāng)你被認(rèn)為 If-Else 很棒時(shí)會(huì)發(fā)生什么:
Simple if-else
只需刪除 else` 塊即可簡(jiǎn)化此過(guò)程,如下圖:
Removed else
看起來(lái)更專(zhuān)業(yè)吧?你會(huì)發(fā)現(xiàn),實(shí)際上根本不需要其他塊。像在這種情況下一樣,你想要在滿(mǎn)足特定條件的情況下執(zhí)行某些操作并立即返回。
價(jià)值分配
如果你要根據(jù)提供的某些輸入為變量分配新值,請(qǐng)停止 If-Else 廢話(huà),一種更具可讀性的方法。
Value assignment with if-else
盡管很簡(jiǎn)單,但它卻很糟糕。首先,If-Else 很容易在這里被開(kāi)關(guān)取代。但是,我們可以通過(guò)完全刪除 else 來(lái)進(jìn)一步簡(jiǎn)化此代碼。
If statements with fast return
如果不使用 else,則我們將剩下干凈的可讀代碼。請(qǐng)注意,我也將樣式更改為快速返回而不是單返回語(yǔ)句。如果已經(jīng)找到正確的值,繼續(xù)測(cè)試一個(gè)值根本沒(méi)有意義。
前提條件檢查
通常,我發(fā)現(xiàn),如果方法提供了無(wú)效的值,則繼續(xù)執(zhí)行是沒(méi)有意義的。假設(shè)我們從以前就有了 DefineGender 方法,要求提供的輸入值必須始終為 0 或 1。
Method without value checks
在沒(méi)有價(jià)值驗(yàn)證的情況下執(zhí)行該方法沒(méi)有任何意義。因此,在允許方法繼續(xù)執(zhí)行之前,我們需要檢查一些先決條件。
應(yīng)用保護(hù)子句防御性編碼技術(shù),你將檢查方法的輸入值,然后繼續(xù)執(zhí)行方法。
Check preconditions with guard clauses
至此,我們確保僅在值落在預(yù)期范圍內(nèi)時(shí)才執(zhí)行主邏輯。現(xiàn)在,IF 也已被三元代替,因?yàn)椴辉傩枰诮Y(jié)尾處默認(rèn)返回"未知"。
將 If-Else 轉(zhuǎn)換為字典,完全避免 If-Else
假設(shè)您需要執(zhí)行一些操作,這些操作將根據(jù)某些條件進(jìn)行選擇,我們知道以后必須添加更多操作。
也許有人傾向于使用久經(jīng)考驗(yàn)的 If-Else。如果添加新操作,則只需簡(jiǎn)單地添加其他內(nèi)容即可。很簡(jiǎn)單 但是,就維護(hù)而言,這種方法不是一個(gè)好的設(shè)計(jì)。
知道我們以后需要添加新的操作后,我們可以將 If-Else 重構(gòu)為字典。
可讀性已大大提高,并且可以更輕松地推斷出該代碼。注意,僅出于說(shuō)明目的將字典放置在方法內(nèi)部。您可能希望從其他地方提供它。
擴(kuò)展應(yīng)用程序,完全避免使用 If-Else
這是一個(gè)稍微高級(jí)的示例。通過(guò)用對(duì)象替換它們,知道何時(shí)甚至完全消除 If。
通常,您會(huì)發(fā)現(xiàn)自己不得不擴(kuò)展應(yīng)用程序的某些部分。作為初級(jí)開(kāi)發(fā)人員,您可能會(huì)傾向于通過(guò)添加額外的 If-Else(即 else-if)語(yǔ)句來(lái)做到這一點(diǎn)。
舉這個(gè)說(shuō)明性的例子。在這里,我們需要將 Order 實(shí)例顯示為字符串。首先,我們只有兩種字符串表示形式:JSON 和純文本。
在此階段使用 If-Else 并不是什么大問(wèn)題,如果我們可以輕松替換其他,只要如前所述即可。
知道我們需要擴(kuò)展應(yīng)用程序的這一部分,這種方法絕對(duì)是不可接受的。
上面的代碼不僅違反了"打開(kāi)/關(guān)閉"原則,而且閱讀得不好,還會(huì)引起可維護(hù)性方面的麻煩。
正確的方法是遵循 SOLID 原則的方法,我們通過(guò)實(shí)施動(dòng)態(tài)類(lèi)型發(fā)現(xiàn)過(guò)程(在本例中為策略模式)來(lái)做到這一點(diǎn)。
重構(gòu)這個(gè)混亂的過(guò)程的過(guò)程如下:
使用公共接口將每個(gè)分支提取到單獨(dú)的策略類(lèi)中。
動(dòng)態(tài)查找實(shí)現(xiàn)通用接口的所有類(lèi)。
根據(jù)輸入決定執(zhí)行哪種策略。
替換上面示例的代碼如下所示。是的,這是更多代碼的方式。它要求您了解類(lèi)型發(fā)現(xiàn)的工作原理。但是動(dòng)態(tài)擴(kuò)展應(yīng)用程序是一個(gè)高級(jí)主題。
我只顯示將替換 If-Else 示例的確切部分。如果要查看所有涉及的對(duì)象,請(qǐng)查看此要點(diǎn)。
讓我們快速瀏覽一下代碼。方法簽名保持不變,因?yàn)檎{(diào)用者不需要了解我們的重構(gòu)。
首先,獲取實(shí)現(xiàn)通用接口 IOrderOutputStrategy 的程序集中的所有類(lèi)型。然后,我們建立一個(gè)字典,格式化程序的 displayName 的名稱(chēng)為 key,類(lèi)型為 value。
然后從字典中選擇格式化程序類(lèi)型,然后嘗試實(shí)例化策略對(duì)象。最后,調(diào)用策略對(duì)象的 ConvertOrderToString。
原文標(biāo)題:CTO:再寫(xiě)if-else,逮著罰款1000!
文章出處:【微信公眾號(hào):算法與數(shù)據(jù)結(jié)構(gòu)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
責(zé)任編輯:haq
-
編程
+關(guān)注
關(guān)注
88文章
3637瀏覽量
93989 -
代碼
+關(guān)注
關(guān)注
30文章
4828瀏覽量
69059
原文標(biāo)題:CTO:再寫(xiě)if-else,逮著罰款1000!
文章出處:【微信號(hào):TheAlgorithm,微信公眾號(hào):算法與數(shù)據(jù)結(jié)構(gòu)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
戈帥的《HarmonyOS從入門(mén)到精通40例》DevEco Studio升級(jí)說(shuō)明
四種方法教你判斷設(shè)備的字節(jié)序
視頻目標(biāo)跟蹤從0到1,概念與方法
![視頻目標(biāo)跟蹤<b class='flag-5'>從</b>0<b class='flag-5'>到</b>1,概念與<b class='flag-5'>方法</b>](https://file.elecfans.com/web2/M00/4E/DC/poYBAGLCjeiALm_WAAAYmfR7Qec474.png)
UART串口通信示例:開(kāi)啟通信寶藏之門(mén)的定位模組LuatOS入門(mén)
![UART串口通信<b class='flag-5'>示例</b>:開(kāi)啟通信寶藏之門(mén)的定位模組LuatOS<b class='flag-5'>入門(mén)</b>](https://file1.elecfans.com/web1/M00/F4/38/wKgZoWcnYy-AeH-rAAs3cKMldkQ680.png)
一種簡(jiǎn)單高效配置FPGA的方法
![一<b class='flag-5'>種</b>簡(jiǎn)單高效配置FPGA的<b class='flag-5'>方法</b>](https://file1.elecfans.com/web2/M00/0A/1C/wKgZomcZ7-WAIjnBAAINroizvyU375.png)
直流無(wú)刷電機(jī)調(diào)速有幾種方法及應(yīng)用
新書(shū)推薦 | TSMaster開(kāi)發(fā)從入門(mén)到精通
![新書(shū)推薦 | TSMaster開(kāi)發(fā)<b class='flag-5'>從</b><b class='flag-5'>入門(mén)</b><b class='flag-5'>到</b>精通](https://file.elecfans.com/web2/M00/40/07/pYYBAGJrUk2AaMaTAAAQONQtdzo461.jpg)
重磅!翹首以盼的《TSMaster開(kāi)發(fā)從入門(mén)到精通》正式出版!
![重磅!翹首以盼的《TSMaster開(kāi)發(fā)<b class='flag-5'>從</b><b class='flag-5'>入門(mén)</b><b class='flag-5'>到</b>精通》正式出版!](https://file.elecfans.com/web2/M00/40/07/pYYBAGJrUk2AaMaTAAAQONQtdzo461.jpg)
MCUXpresso IDE下在線(xiàn)聯(lián)合調(diào)試雙核MCU工程的三種方法
![MCUXpresso IDE下在線(xiàn)聯(lián)合調(diào)試雙核MCU工程的三<b class='flag-5'>種方法</b>](https://file1.elecfans.com/web2/M00/01/47/wKgZoma0cXeABzT3AAA1KoC8H4g757.png)
pwm脈寬調(diào)制的四種方法有哪些
人臉檢測(cè)的五種方法各有什么特征和優(yōu)缺點(diǎn)
ARM嵌入式Linux 系統(tǒng)開(kāi)發(fā)從入門(mén)到精通
靜電ESD整改實(shí)踐:從基礎(chǔ)到高級(jí)的應(yīng)對(duì)策略?
![靜電ESD整改實(shí)踐:<b class='flag-5'>從</b>基礎(chǔ)<b class='flag-5'>到</b><b class='flag-5'>高級(jí)</b>的應(yīng)對(duì)策略?](https://file1.elecfans.com//web2/M00/C1/14/wKgaomXS-AqAYuQXAAF-GD52Rgw472.jpg)
評(píng)論