當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]來源:翻譯自:NicklasMillard的文章《BetterSoftwareWithoutIf-Else》注:本文并不肯定或者否定哪一種寫法,僅僅為大家提供一些其他的編碼思路或者一些值得借鑒的點(diǎn)子,希望大家能在公眾號(hào)的每一篇文章中都能有所收獲,同時(shí)歡迎探討!設(shè)計(jì)更好的軟件,替換If-Else的5種方法。入門到高級(jí)示例讓我直接說這句話:If-Else通常是一個(gè)糟糕的選擇。它導(dǎo)致設(shè)計(jì)復(fù)雜,代碼可讀性差,并且可能導(dǎo)致重構(gòu)困難。但是,If-Else已成為事實(shí)上的代碼分支解決方案,這確實(shí)是有道理的。這是向所有有抱負(fù)的開發(fā)人員講授的第一件事。不幸的是,許多開發(fā)人員從來沒有前進(jìn)到更合適的分支策略。有些人的...


來源:翻譯自: Nicklas Millard 的文章《Better Software Without If-Else

注:本文并不肯定或者否定哪一種寫法,僅僅為大家提供一些其他的編碼思路或者一些值得借鑒的點(diǎn)子,希望大家能在公眾號(hào)的每一篇文章中都能有所收獲,同時(shí)歡迎探討!


設(shè)計(jì)更好的軟件,替換 If-Else 的 5 種方法。入門到高級(jí)示例


讓我直接說這句話:If-Else 通常是一個(gè)糟糕的選擇。


它導(dǎo)致設(shè)計(jì)復(fù)雜,代碼可讀性差,并且可能導(dǎo)致重構(gòu)困難。


但是,If-Else 已成為事實(shí)上的代碼分支解決方案,這確實(shí)是有道理的。這是向所有有抱負(fù)的開發(fā)人員講授的第一件事。不幸的是,許多開發(fā)人員從來沒有前進(jìn)到更合適的分支策略。


有些人的口頭禪是:If-Else 是一把錘子,一切都是釘子。


無(wú)法區(qū)分何時(shí)使用更合適的方法是區(qū)分大三學(xué)生和大三學(xué)生的原因之一。


我將向您展示一些技巧和模式,這些技巧和模式將終結(jié)這種可怕的做法。

每個(gè)示例的難度都會(huì)增加。


完全不必要的 else 塊

面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!

Simple if-else

只需刪除 else` 塊即可簡(jiǎn)化此過程。

面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!Removed else

看起來更專業(yè)吧?

您會(huì)經(jīng)常發(fā)現(xiàn),實(shí)際上根本不需要其他塊。像在這種情況下一樣,您想要在滿足特定條件的情況下執(zhí)行某些操作并立即返回。


價(jià)值分配

如果您要根據(jù)提供的某些輸入為變量分配新值,請(qǐng)停止 If-Else 廢話 - 一種更具可讀性的方法。

面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!

Value assignment with if-else


盡管很簡(jiǎn)單,但它卻很糟糕。首先,If-Else 很容易在這里被開關(guān)取代。但是,我們可以通過完全刪除 else 來進(jìn)一步簡(jiǎn)化此代碼。


面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!


前提條件

如果您要根據(jù)提供的某些輸入為變量分配新值,請(qǐng)停止 If-Else 廢話 - 一種更具可讀性的方法


通常,我發(fā)現(xiàn),如果方法提供了無(wú)效的值,則繼續(xù)執(zhí)行是沒有意義的。假設(shè)我們從以前就有了 DefineGender 方法,要求提供的輸入值必須始終為 0 或 1。


面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!

Method without value checks

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


應(yīng)用保護(hù)子句防御性編碼技術(shù),您將檢查方法的輸入值,然后繼續(xù)執(zhí)行方法。

面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!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)行選擇,我們知道以后必須添加更多操作。



面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!

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


知道我們以后需要添加新的操作后,我們可以將 If-Else 重構(gòu)為字典。

面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!可讀性已大大提高,并且可以更輕松地推斷出該代碼。
“注意,僅出于說明目的將字典放置在方法內(nèi)部。您可能希望從其他地方提供它?!?/span>



擴(kuò)展應(yīng)用程序—完全避免使用 If-Else

這是一個(gè)稍微高級(jí)的示例。


通過用對(duì)象替換它們,知道何時(shí)甚至完全消除 If。


通常,您會(huì)發(fā)現(xiàn)自己不得不擴(kuò)展應(yīng)用程序的某些部分。作為初級(jí)開發(fā)人員,您可能會(huì)傾向于通過添加額外的 If-Else(即 else-if)語(yǔ)句來做到這一點(diǎn)。


舉這個(gè)說明性的例子。在這里,我們需要將 Order 實(shí)例顯示為字符串。首先,我們只有兩種字符串表示形式:JSON 和純文本。在此階段使用 If-Else 并不是什么大問題,如果我們可以輕松替換其他,只要如前所述即可。

面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!知道我們需要擴(kuò)展應(yīng)用程序的這一部分,這種方法絕對(duì)是不可接受的。

上面的代碼不僅違反了 "打開 / 關(guān)閉" 原則,而且閱讀得不好,還會(huì)引起可維護(hù)性方面的麻煩。


正確的方法是遵循 SOLID 原則的方法 - 我們通過實(shí)施動(dòng)態(tài)類型發(fā)現(xiàn)過程(在本例中為策略模式)來做到這一點(diǎn)。


重構(gòu)這個(gè)混亂的過程的過程如下:

  • 使用公共接口將每個(gè)分支提取到單獨(dú)的策略類中
  • 動(dòng)態(tài)查找實(shí)現(xiàn)通用接口的所有類
  • 根據(jù)輸入決定執(zhí)行哪種策略
  • 替換上面示例的代碼如下所示。是的,這是更多代碼的方式。它要求您了解類型發(fā)現(xiàn)的工作原理。但是動(dòng)態(tài)擴(kuò)展應(yīng)用程序是一個(gè)高級(jí)主題。

我只顯示將替換 If-Else 示例的確切部分。如果要查看所有涉及的對(duì)象,請(qǐng)查看此要點(diǎn)。面試官?|?寫if?時(shí)不帶?else,你的代碼會(huì)更好!

讓我們快速瀏覽一下代碼。
方法簽名保持不變,因?yàn)檎{(diào)用者不需要了解我們的重構(gòu)。
首先,獲取實(shí)現(xiàn)通用接口 IOrderOutputStrategy 的程序集中的所有類型。然后,我們建立一個(gè)字典,格式化程序的 displayName 的名稱為 key,類型為 value。
然后從字典中選擇格式化程序類型,然后嘗試實(shí)例化策略對(duì)象。最后,調(diào)用策略對(duì)象的 ConvertOrderToString。
作者介紹:
Nicklas Millard 在丹麥的四大咨詢公司之一中擔(dān)任高級(jí)技術(shù)顧問。他主要擔(dān)任客戶項(xiàng)目的首席開發(fā)人員和解決方案架構(gòu)師。
他一直在為商業(yè)客戶和政府機(jī)構(gòu)開發(fā)軟件,例如國(guó)防部,教育部,丹麥環(huán)境與食品部,國(guó)家警察,丹麥勞動(dòng)力市場(chǎng)和招聘局以及 rstad。select_card mp_profile_iframe" data-pluginname="mpprofile" data-id="MzU0OTE4MzYzMw==" data-headimg="http://mmbiz.qpic.cn/mmbiz_png/fEsWkVrSk55KKLFaGCDRURMvFtPXf9fZXJOHOFsA3Ye8Qbibf3qHLkBQNpdjicAVpPf2T03EcakjAFbwqicjXSibXA/0?wx_fmt=png" data-nickname="架構(gòu)師社區(qū)" data-alias="devabc" data-signature="架構(gòu)師社區(qū),專注分享架構(gòu)師技術(shù)干貨,架構(gòu)師行業(yè)秘聞,匯集各類奇妙好玩的架構(gòu)師話題和流行的架構(gòu)師動(dòng)向!" data-from="0">

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉