0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

為什么要寫(xiě)糟糕的代碼?什么是整潔的代碼?

汽車ECU開(kāi)發(fā) ? 來(lái)源:稀土掘金 ? 作者:unebrise ? 2022-11-21 10:58 ? 次閱讀

寫(xiě)在前面

這個(gè)文章本來(lái)沒(méi)打算寫(xiě),直到經(jīng)歷了幾次代碼評(píng)審會(huì)議之后,我意識(shí)到自己編碼方式還不成系統(tǒng),仍然需要進(jìn)行系統(tǒng)化的學(xué)習(xí),掌握前輩們總結(jié)出的最適用的規(guī)律無(wú)疑是一種好的方式。恰好很早之前就收藏了這本代碼整潔之道,便決定趁著閑暇之際閱讀總結(jié)一下,如果想系統(tǒng)學(xué)習(xí)的話建議還是讀書(shū),本文檔只是作為自己的記錄用。

一個(gè)人的職業(yè)素養(yǎng)體現(xiàn)在解決問(wèn)題的方式、步驟以及反思的程度,而不在于這個(gè)問(wèn)題本身的難度。思考一個(gè)問(wèn)題:一個(gè)技術(shù)人員要具備哪些素質(zhì)可以被認(rèn)為是專業(yè)人員呢?如果還不具備需要如何改變才能被視為專業(yè)人士呢?

整潔代碼

一、為什么要寫(xiě)糟糕的代碼?

每個(gè)人都有自己的原因,相信很多人都會(huì)想著等有時(shí)間的話再進(jìn)行代碼優(yōu)化,但是要記住一句話:稍后等于永不。

二、混亂代碼的代價(jià)?

后續(xù)難以維護(hù)和修改,生產(chǎn)力和時(shí)間呈現(xiàn)負(fù)相關(guān)。

三、什么是整潔的代碼?

整潔的代碼只做好一件事:每個(gè)類、每個(gè)函數(shù)、每個(gè)模塊都專注于一事,完全不受四周細(xì)節(jié)的干擾和污染。

更全面的概括是:減少重復(fù)代碼、提高表達(dá)力、提早構(gòu)建簡(jiǎn)單抽象。

更具體的實(shí)現(xiàn):請(qǐng)接著往下看吧!

更好的變量命名

一、見(jiàn)名知意

二、抽象工廠:接口不要命名為IShapeFactory,前導(dǎo)字母對(duì)于用戶來(lái)說(shuō)其實(shí)是干擾,用戶只需要知道那是個(gè)抽象工廠,建議使用CShapeFactory或許體驗(yàn)更好

三、類名要用名詞,方法要用動(dòng)詞,詞性相近的get、fetch這種詞不應(yīng)出現(xiàn)在一起,可以添加后綴getNumber、fetchData實(shí)現(xiàn)相同的效果

四、別害怕長(zhǎng)名字:使用描述性的名稱,哪怕比較長(zhǎng)也比短而令人費(fèi)解的名稱好

更好的函數(shù)

一、函數(shù)的結(jié)構(gòu)本質(zhì)上要短小、再短小,以不容納if/else if/else嵌套結(jié)構(gòu)為目標(biāo)

二、只做一件事:正如前面所說(shuō),函數(shù)只做好一件事就足夠了,標(biāo)志就是“看是否還能拆出一個(gè)函數(shù),該函數(shù)不僅只是單純地重新詮釋其實(shí)現(xiàn)”

三、每個(gè)函數(shù)一個(gè)抽象層級(jí):代碼一般是“自頂向下”的閱讀順序,每個(gè)函數(shù)后面跟著的應(yīng)該是下一抽象層級(jí)的函數(shù)

[抽象層級(jí):getHtml函數(shù)位于較高抽象層,pagePathName = pathParser.render(pagePath)位于中間抽象層,.append(" ")則位于較低抽象層]

四、switch語(yǔ)句:天生就需要做N件事,但是可以將其放置在較低抽象層級(jí),但是當(dāng)出現(xiàn)新的類型時(shí)會(huì)違反“單一權(quán)責(zé)原則、開(kāi)放閉合原則”,此時(shí)最好創(chuàng)建多態(tài)對(duì)象

//原文中:對(duì)于每個(gè)case分支進(jìn)行單獨(dú)處理,添加新類型不必修改原來(lái)的代碼增加新的處理類即可
functiongetName(name){
switch(name){
case'ming':
returnnewClassMing(name);
case'hu':
returnnewClassHu(name);
case'uzi':
returnnewClassUzi(name);
default:
thrownewClassCommon(name);
}
}

//我更喜歡用另一種方法:修改只需要在對(duì)象里修改即可,且提高了函數(shù)的簡(jiǎn)潔性
constnameCollectionUtils={
 ming:newClassMing('ming');
hu:newClassHu('hu');
uzi:newClassUzi('uzi');
}
functiongetName(name){
returnnameCollectionUtils.hasOwn(name)?nameCollectionUtils[name]:newClassCommon(name)
}

五、函數(shù)參數(shù)最多不多于兩個(gè):包括輸入?yún)?shù)和輸出參數(shù)

六、無(wú)副作用:函數(shù)內(nèi)部不要做出未能預(yù)期的改動(dòng),不要對(duì)外部產(chǎn)生影響

七、使用異常替代返回錯(cuò)誤碼:使用try...catch替代多層級(jí)的if嵌套,永遠(yuǎn)走在主路上,不要過(guò)多考慮邊界,這樣可以讓你一直保持思維連貫

八、錯(cuò)誤處理單獨(dú)抽出:這一條我認(rèn)為可以視情況而定,畢竟抽出僅僅是為了美觀

九、別重復(fù):多個(gè)函數(shù)使用的相同邏輯的代碼一定要抽出,可以參考面向?qū)ο蟮幕悾岸碎_(kāi)發(fā)中的面向組件編程、面向模塊編程也是這種思想

注釋&格式

每個(gè)人有每個(gè)人的習(xí)慣,采取一些通用準(zhǔn)則即可,畢竟如何太過(guò)離譜在公司是會(huì)挨打的~

錯(cuò)誤處理

也沒(méi)有什么固定的章程,最好采取try...catch優(yōu)先的原則

邊界

總結(jié)而言,使用自己可以控制的代碼

單元測(cè)試

現(xiàn)在的互聯(lián)網(wǎng)企業(yè)絕大多數(shù)都是敏捷式開(kāi)發(fā),很少有能遵守測(cè)試驅(qū)動(dòng)原則的公司,而且為了保證進(jìn)度很少會(huì)有技術(shù)團(tuán)隊(duì)會(huì)去要求單元測(cè)試,所以這一條仁者見(jiàn)仁吧,個(gè)人認(rèn)為這一項(xiàng)的實(shí)際實(shí)現(xiàn)只能是一個(gè)比較美好的愿景。

一、類的組織:按照下面的順序,不要暴露出內(nèi)部屬性,利用方法達(dá)到同樣的目的

classDemoOrganization{
staticsname='sname'
privatepname='pname'
private_pname='_pname'
protectedtname='tname'

publicgetPublicName(){
returnthis.pname
}
private_getPrivateName(){
returnthis._pname
}
}

二、單一權(quán)責(zé)原則(SPR):類或模塊應(yīng)有且只有一條加以修改的理由,實(shí)現(xiàn)了這個(gè)原則的類更易得到復(fù)用

三、保持內(nèi)聚性:類中定義的變量應(yīng)被盡可能多的方法使用到,如果不能滿足的話就把使用到變量的函數(shù)拆分成小類

四、開(kāi)放封閉原則(OCP):類應(yīng)當(dāng)對(duì)擴(kuò)展開(kāi)放,對(duì)修改封閉,通過(guò)子類化手段可以實(shí)現(xiàn)新功能的添加的同時(shí)不觸及其他類

五、依賴倒置原則(DIP):類應(yīng)當(dāng)依賴于抽象而不是依賴于具體細(xì)節(jié)

六、解耦:不同方法和模塊間不要互相產(chǎn)生影響,即“分而治之”、“化整為零”

系統(tǒng)

一、構(gòu)造和使用分開(kāi):構(gòu)造的細(xì)節(jié)應(yīng)隔離與應(yīng)用程序代碼之外,使用者只能獲取構(gòu)造者想讓使用者獲得的東西

二、設(shè)計(jì)時(shí)要能滿足從簡(jiǎn)單到復(fù)雜的更新迭代

迭進(jìn)

總結(jié)上述,只要遵守以下原則,就可以得到一個(gè)具有良好設(shè)計(jì)的可迭進(jìn)的程序:

運(yùn)行所有測(cè)試

不可重復(fù)

表達(dá)了程序員的意圖

盡可能減少類和方法的數(shù)量

以上規(guī)則按重要程度排列

并發(fā)編程

首先要了解“線程”這個(gè)概念:CPU調(diào)度的最小單位,區(qū)別于“進(jìn)程”是資源分配的最小單位。區(qū)別見(jiàn)下方表格:

分類 數(shù)據(jù)共享 消耗資源 是否影響兄弟程序 最大可擴(kuò)展維度 是否有鎖
進(jìn)程 多機(jī)
線程 簡(jiǎn)單 可能影響所在進(jìn)程 多核

如果說(shuō)對(duì)象是過(guò)程的抽象,那么線程是調(diào)度的抽象

前端使用的js語(yǔ)言是瀏覽器腳本語(yǔ)言,最主要的用途是和用戶互動(dòng)和操作DOM,這決定了js只能是單線程否則會(huì)產(chǎn)生復(fù)雜的同步問(wèn)題,但是js仍然可以模擬并發(fā)執(zhí)行,具體實(shí)現(xiàn)自行查詢相關(guān)資料

當(dāng)前還沒(méi)學(xué)習(xí)到并發(fā)編程的語(yǔ)言,以后碰到再補(bǔ)充學(xué)習(xí)

重構(gòu)

這個(gè)模塊我認(rèn)為是最重要的模塊,甚至比怎么去編寫(xiě)新的程序更重要,因?yàn)橐粋€(gè)公司的沉積項(xiàng)目的數(shù)量是巨大的,很可能會(huì)對(duì)其中幾個(gè)甚至更多進(jìn)行重構(gòu)(還是因?yàn)橹按a寫(xiě)的太爛無(wú)法維護(hù)),所以重構(gòu)中需要注意的點(diǎn)也要有一個(gè)清晰的認(rèn)知。

只需要遵守一條原則:簽入的代碼比簽出的更整潔。

寫(xiě)在最后

以上是我從前端角度總結(jié)的從這本書(shū)中得到的一些收獲,但是每個(gè)人都會(huì)有每個(gè)人自己的理解,所以還是推薦自己去讀一遍這本書(shū),不需要多精細(xì)只要熟悉一下這些概念提出來(lái)的場(chǎng)景,相信會(huì)有更大的收獲。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • SPR
    SPR
    +關(guān)注

    關(guān)注

    0

    文章

    20

    瀏覽量

    11487
  • DIP
    DIP
    +關(guān)注

    關(guān)注

    0

    文章

    241

    瀏覽量

    30144
  • OCP
    OCP
    +關(guān)注

    關(guān)注

    0

    文章

    79

    瀏覽量

    16431
  • DOM
    DOM
    +關(guān)注

    關(guān)注

    0

    文章

    18

    瀏覽量

    9575

原文標(biāo)題:常說(shuō)的代碼整潔到底是什么?

文章出處:【微信號(hào):eng2mot,微信公眾號(hào):汽車ECU開(kāi)發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Gmapping源代碼

    Gmapping源代碼.docx
    發(fā)表于 11-16 13:42 ?0次下載

    如何自動(dòng)生成verilog代碼

    介紹幾種自動(dòng)生成verilog代碼的方法。
    的頭像 發(fā)表于 11-05 11:45 ?316次閱讀
    如何自動(dòng)生成verilog<b class='flag-5'>代碼</b>

    MSP代碼保護(hù)功能

    電子發(fā)燒友網(wǎng)站提供《MSP代碼保護(hù)功能.pdf》資料免費(fèi)下載
    發(fā)表于 09-21 09:14 ?0次下載
    MSP<b class='flag-5'>代碼</b>保護(hù)功能

    代碼整潔之道-大師眼中的整潔代碼是什么樣

    模糊,帶著這個(gè)問(wèn)題,本人讀完了世界軟件開(kāi)發(fā)大師馬丁的《代碼整潔之道》這本書(shū),來(lái)了解下大師眼中的整潔代碼畫(huà)像是什么樣的,相信能給你帶來(lái)不一樣的理解和感悟。 關(guān)于
    的頭像 發(fā)表于 09-09 16:30 ?340次閱讀
    <b class='flag-5'>代碼</b><b class='flag-5'>整潔</b>之道-大師眼中的<b class='flag-5'>整潔</b><b class='flag-5'>代碼</b>是什么樣

    軟件設(shè)計(jì)哲學(xué):新“代碼整潔之道”

    工作三年以來(lái)一直對(duì)寫(xiě)出設(shè)計(jì)優(yōu)雅且可讀性較好的代碼抱有執(zhí)念,最初接觸到的關(guān)于代碼整潔和軟件設(shè)計(jì)的書(shū)是《代碼整潔之道》,這本書(shū)大概在我入職半年時(shí)
    的頭像 發(fā)表于 07-22 12:18 ?244次閱讀
    軟件設(shè)計(jì)哲學(xué):新“<b class='flag-5'>代碼</b><b class='flag-5'>整潔</b>之道”

    國(guó)內(nèi)低代碼平臺(tái)推薦--萬(wàn)界星空科技低代碼平臺(tái)

    代碼平臺(tái)是一種應(yīng)用程序,它為編程提供圖形用戶界面,從而以極快的速度開(kāi)發(fā)代碼,減少傳統(tǒng)編程工作。 這些工具有助于快速開(kāi)發(fā)代碼,最大限度地減少手工編碼的工作量。這些平臺(tái)不僅有助于編碼,還有助于快速設(shè)置和部署。
    的頭像 發(fā)表于 07-18 15:39 ?298次閱讀
    國(guó)內(nèi)低<b class='flag-5'>代碼</b>平臺(tái)推薦--萬(wàn)界星空科技低<b class='flag-5'>代碼</b>平臺(tái)

    該如何提高代碼容錯(cuò)率、降低代碼耦合度?

    提高RT-Thread代碼的容錯(cuò)率和降低耦合度是確保代碼質(zhì)量和可維護(hù)性的關(guān)鍵,下面列舉了幾種在編寫(xiě)代碼時(shí),提高代碼容錯(cuò)率和降低耦合度的思路。讓我們一起來(lái)看看吧~一、提高
    的頭像 發(fā)表于 06-26 08:10 ?669次閱讀
    該如何提高<b class='flag-5'>代碼</b>容錯(cuò)率、降低<b class='flag-5'>代碼</b>耦合度?

    手柄控制代碼及使用方法

    手柄控制代碼及使用方法
    的頭像 發(fā)表于 05-15 10:19 ?1822次閱讀

    藍(lán)牙遙控代碼及使用

    藍(lán)牙遙控代碼及使用
    的頭像 發(fā)表于 05-15 10:15 ?844次閱讀

    如何提升代碼質(zhì)量與效率的秘訣

    提高編程能力其實(shí)沒(méi)有捷徑,最佳方式就是多寫(xiě)代碼。 不過(guò),除了寫(xiě)大量代碼,提升編程能力還需要大量閱讀別人寫(xiě)的代碼。
    的頭像 發(fā)表于 04-28 14:53 ?397次閱讀
    如何提升<b class='flag-5'>代碼</b>質(zhì)量與效率的秘訣

    請(qǐng)問(wèn)STM32CubeIDE如何查看代碼總行數(shù)?

    近期填寫(xiě)資料,需要寫(xiě)當(dāng)前項(xiàng)目源代碼總行數(shù),使用的STM32CubeIDE開(kāi)發(fā)的,想請(qǐng)教一下,這個(gè)IDE怎么看代碼的總行數(shù)?
    發(fā)表于 03-28 07:07

    g代碼和m代碼表示什么功能

    G代碼和M代碼是數(shù)控機(jī)床程序中常用的兩種指令代碼,用于控制數(shù)控機(jī)床的工作動(dòng)作和運(yùn)動(dòng)方式。 G代碼是指控制機(jī)床工作動(dòng)作的指令代碼,它是一種簡(jiǎn)單
    的頭像 發(fā)表于 02-14 15:49 ?4344次閱讀

    ABB變頻器故障代碼

    ? ? ? ABB變頻器是非常普遍的工業(yè)設(shè)備。在許多行業(yè)中應(yīng)用廣泛。然而,無(wú)論是由于使用年限或其他因素,ABB變頻器故障或出現(xiàn)錯(cuò)誤的可能性是存在的。本文將為您介紹ABB變頻器故障代碼表并提供詳實(shí)
    的頭像 發(fā)表于 02-02 17:10 ?4505次閱讀
    ABB變頻器故障<b class='flag-5'>代碼</b>表

    淺談代碼優(yōu)化與過(guò)度設(shè)計(jì)

    本文記錄了作者從“代碼優(yōu)化”到“過(guò)度設(shè)計(jì)”的典型思考過(guò)程,這過(guò)程中涉及了很多Java的語(yǔ)法糖及設(shè)計(jì)模式的東西,很典型,能啟發(fā)思考,遂記錄下來(lái)。 有一天Review師妹的代碼,看到一行很難看的代碼
    的頭像 發(fā)表于 01-19 10:05 ?549次閱讀
    淺談<b class='flag-5'>代碼</b>優(yōu)化與過(guò)度設(shè)計(jì)

    BQ3568_代碼下載

    BQ3568_代碼下載
    的頭像 發(fā)表于 01-11 11:34 ?622次閱讀