CTO怒了:再写if-else,逮着罚款1000!
來自公眾號(hào):51CTO技術(shù)棧
作者:Nicklas Millard,在丹麥的四大咨詢公司之一中擔(dān)任高級(jí)技術(shù)顧問,主要擔(dān)任客戶項(xiàng)目的首席開發(fā)人員和解決方案架構(gòu)師。
編輯:陶家龍
出處:https://medium.com/swlh/5-ways-to-replace-if-else-statements-857c0ff19357
“
本文并不肯定或者否定哪一種寫法,僅僅為大家提供一些其他的編碼思路或者一些值得借鑒的點(diǎn)子。
設(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 是一把錘子,一切都是釘子。
我將向大家展示一些技巧和模式,這些技巧和模式將終結(jié)這種可怕的做法。每個(gè)示例的難度都會(huì)增加。
完全不必要的 Else 塊
這也許是那些初級(jí)開發(fā)人員最負(fù)罪的之一。下面的示例很好地說明了當(dāng)你被認(rèn)為 If-Else 很棒時(shí)會(huì)發(fā)生什么:
Simple if-else
只需刪除 else` 塊即可簡化此過程,如下圖:
Removed else
看起來更專業(yè)吧?你會(huì)發(fā)現(xiàn),實(shí)際上根本不需要其他塊。像在這種情況下一樣,你想要在滿足特定條件的情況下執(zhí)行某些操作并立即返回。
價(jià)值分配
如果你要根據(jù)提供的某些輸入為變量分配新值,請停止 If-Else 廢話,一種更具可讀性的方法。
Value assignment with if-else
盡管很簡單,但它卻很糟糕。首先,If-Else 很容易在這里被開關(guān)取代。但是,我們可以通過完全刪除 else 來進(jìn)一步簡化此代碼。
If statements with fast return
如果不使用 else,則我們將剩下干凈的可讀代碼。請注意,我也將樣式更改為快速返回而不是單返回語句。如果已經(jīng)找到正確的值,繼續(xù)測試一個(gè)值根本沒有意義。
前提條件檢查
通常,我發(fā)現(xiàn),如果方法提供了無效的值,則繼續(xù)執(zhí)行是沒有意義的。假設(shè)我們從以前就有了 DefineGender 方法,要求提供的輸入值必須始終為 0 或 1。
Method without value checks
在沒有價(jià)值驗(yàn)證的情況下執(zhí)行該方法沒有任何意義。因此,在允許方法繼續(xù)執(zhí)行之前,我們需要檢查一些先決條件。
應(yīng)用保護(hù)子句防御性編碼技術(shù),你將檢查方法的輸入值,然后繼續(xù)執(zhí)行方法。
Check preconditions with guard clauses
至此,我們確保僅在值落在預(yù)期范圍內(nèi)時(shí)才執(zhí)行主邏輯?,F(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。如果添加新操作,則只需簡單地添加其他內(nèi)容即可。很簡單 但是,就維護(hù)而言,這種方法不是一個(gè)好的設(shè)計(jì)。
知道我們以后需要添加新的操作后,我們可以將 If-Else 重構(gòu)為字典。
可讀性已大大提高,并且可以更輕松地推斷出該代碼。注意,僅出于說明目的將字典放置在方法內(nèi)部。您可能希望從其他地方提供它。
擴(kuò)展應(yīng)用程序,完全避免使用 If-Else
這是一個(gè)稍微高級(jí)的示例。通過用對象替換它們,知道何時(shí)甚至完全消除 If。
通常,您會(huì)發(fā)現(xiàn)自己不得不擴(kuò)展應(yīng)用程序的某些部分。作為初級(jí)開發(fā)人員,您可能會(huì)傾向于通過添加額外的 If-Else(即 else-if)語句來做到這一點(diǎn)。
舉這個(gè)說明性的例子。在這里,我們需要將 Order 實(shí)例顯示為字符串。首先,我們只有兩種字符串表示形式:JSON 和純文本。
在此階段使用 If-Else 并不是什么大問題,如果我們可以輕松替換其他,只要如前所述即可。
知道我們需要擴(kuò)展應(yīng)用程序的這一部分,這種方法絕對是不可接受的。
上面的代碼不僅違反了"打開/關(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 示例的確切部分。如果要查看所有涉及的對象,請查看此要點(diǎn)。
讓我們快速瀏覽一下代碼。方法簽名保持不變,因?yàn)檎{(diào)用者不需要了解我們的重構(gòu)。
首先,獲取實(shí)現(xiàn)通用接口 IOrderOutputStrategy 的程序集中的所有類型。然后,我們建立一個(gè)字典,格式化程序的 displayName 的名稱為 key,類型為 value。
然后從字典中選擇格式化程序類型,然后嘗試實(shí)例化策略對象。最后,調(diào)用策略對象的 ConvertOrderToString。
- EOF -
想要加入中生代架構(gòu)群的小伙伴,請?zhí)砑尤汉匣锶?strong>大白的微信
申請備注(姓名+公司+技術(shù)方向)才能通過哦!
阿里技術(shù)精彩文章推薦
往期推薦
深度:揭秘阿里巴巴的客群畫像
多隆:從工程師到阿里巴巴合伙人
阿里技術(shù)專家楚衡:架構(gòu)制圖的工具與方法論
螞蟻集團(tuán)技術(shù)專家山丘:性能優(yōu)化常見壓測模型及優(yōu)缺點(diǎn)
阿里文娛技術(shù)專家戰(zhàn)獒: 領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)詳解之What, Why, How?
阿里專家馬飛翔:一文讀懂架構(gòu)整潔之道
阿里專家常昊:新人如何上手項(xiàng)目管理?
螞蟻集團(tuán)沈凋墨:Kubernetes-微內(nèi)核的分布式操作系統(tǒng)
阿里合伙人范禹:常掛在阿里技術(shù)人嘴邊的四句土話
阿里技術(shù)專家都鐸:一文搞懂技術(shù)債
支付寶研究員兼OceanBase總架構(gòu)師楊傳輝:我在數(shù)據(jù)庫夢之隊(duì)的十年成長路
阿里技術(shù)專家麒燁:修煉測試基本功
阿里計(jì)算平臺(tái)掌門人賈揚(yáng)清:我對人工智能方向的一點(diǎn)淺見
螞蟻資深算法專家周俊:從原理到落地,支付寶如何打造保護(hù)隱私的共享智能?
阿里高級(jí)技術(shù)專家簫逸:如何畫好一張架構(gòu)圖?
阿里高級(jí)技術(shù)專家張建飛:應(yīng)用架構(gòu)分離業(yè)務(wù)邏輯和技術(shù)細(xì)節(jié)之道
螞蟻科技 Service Mesh 落地實(shí)踐與挑戰(zhàn) | GIAC 實(shí)錄
阿里6年,我的技術(shù)蛻變之路!
螞蟻集團(tuán)涵暢:再啟程,Service Mesh 前路雖長,尤可期許
阿里P9專家右軍:大話軟件質(zhì)量穩(wěn)定性
阿里合伙人程立:阿里15年,我撕掉了身上兩個(gè)標(biāo)簽
阿里高工流生 | 云原生時(shí)代的 DevOps 之道
阿里高級(jí)技術(shù)專家邱小俠:微服務(wù)架構(gòu)的理論基礎(chǔ) - 康威定律
阿里P9專家右軍:以終為始的架構(gòu)設(shè)計(jì)
阿里P8架構(gòu)師:淘寶技術(shù)架構(gòu)從1.0到4.0的架構(gòu)變遷!12頁P(yáng)PT詳解
阿里技術(shù):如何畫出一張合格的技術(shù)架構(gòu)圖?
螞蟻資深技術(shù)專家王旭:開源項(xiàng)目是如何讓這個(gè)世界更安全的?
阿里資深技術(shù)專家崮德:8 個(gè)影響我職業(yè)生涯的重要技能
儒梟:我看技術(shù)人的成長路徑
阿里高級(jí)技術(shù)專家宋意:平凡人在阿里十年的成長之旅
阿里技術(shù)專家甘盤:淺談雙十一背后的支付寶LDC架構(gòu)和其CAP分析
阿里技術(shù)專家光錐:億級(jí)長連網(wǎng)關(guān)的云原生演進(jìn)之路
阿里云原生張羽辰:服務(wù)發(fā)現(xiàn)技術(shù)選型那點(diǎn)事兒
螞蟻研究員玉伯:做一個(gè)簡單自由有愛的技術(shù)人
阿里高級(jí)技術(shù)專家至簡: Service Mesh 在超大規(guī)模場景下的落地挑戰(zhàn)
阿里巴巴山獵:手把手教你玩轉(zhuǎn)全鏈路監(jiān)控
阿里涉江:你真的會(huì)學(xué)習(xí)嗎?從結(jié)構(gòu)化思維說起
螞蟻金服資深技術(shù)專家經(jīng)國:云原生時(shí)代微服務(wù)的高可用架構(gòu)設(shè)計(jì)
深入分布式緩存之EVCache探秘開局篇
? ?END ? ?? #架構(gòu)師必備# 新人創(chuàng)作打卡挑戰(zhàn)賽發(fā)博客就能抽獎(jiǎng)!定制產(chǎn)品紅包拿不停!總結(jié)
以上是生活随笔為你收集整理的CTO怒了:再写if-else,逮着罚款1000!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 《机器学习实战》chapter02 K-
- 下一篇: 架构师,是否需要写代码?