国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

為什么要寫糟糕的代碼?什么是整潔的代碼?

汽車ECU開發 ? 來源:稀土掘金 ? 作者:unebrise ? 2022-11-21 10:58 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

寫在前面

這個文章本來沒打算寫,直到經歷了幾次代碼評審會議之后,我意識到自己編碼方式還不成系統,仍然需要進行系統化的學習,掌握前輩們總結出的最適用的規律無疑是一種好的方式。恰好很早之前就收藏了這本代碼整潔之道,便決定趁著閑暇之際閱讀總結一下,如果想系統學習的話建議還是讀書,本文檔只是作為自己的記錄用。

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

整潔代碼

一、為什么要寫糟糕的代碼?

每個人都有自己的原因,相信很多人都會想著等有時間的話再進行代碼優化,但是要記住一句話:稍后等于永不。

二、混亂代碼的代價?

后續難以維護和修改,生產力和時間呈現負相關。

三、什么是整潔的代碼?

整潔的代碼只做好一件事:每個類、每個函數、每個模塊都專注于一事,完全不受四周細節的干擾和污染。

更全面的概括是:減少重復代碼、提高表達力、提早構建簡單抽象。

更具體的實現:請接著往下看吧!

更好的變量命名

一、見名知意

二、抽象工廠:接口不要命名為IShapeFactory,前導字母對于用戶來說其實是干擾,用戶只需要知道那是個抽象工廠,建議使用CShapeFactory或許體驗更好

三、類名要用名詞,方法要用動詞,詞性相近的get、fetch這種詞不應出現在一起,可以添加后綴getNumber、fetchData實現相同的效果

四、別害怕長名字:使用描述性的名稱,哪怕比較長也比短而令人費解的名稱好

更好的函數

一、函數的結構本質上要短小、再短小,以不容納if/else if/else嵌套結構為目標

二、只做一件事:正如前面所說,函數只做好一件事就足夠了,標志就是“看是否還能拆出一個函數,該函數不僅只是單純地重新詮釋其實現”

三、每個函數一個抽象層級:代碼一般是“自頂向下”的閱讀順序,每個函數后面跟著的應該是下一抽象層級的函數

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

四、switch語句:天生就需要做N件事,但是可以將其放置在較低抽象層級,但是當出現新的類型時會違反“單一權責原則、開放閉合原則”,此時最好創建多態對象

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

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

五、函數參數最多不多于兩個:包括輸入參數和輸出參數

六、無副作用:函數內部不要做出未能預期的改動,不要對外部產生影響

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

八、錯誤處理單獨抽出:這一條我認為可以視情況而定,畢竟抽出僅僅是為了美觀

九、別重復:多個函數使用的相同邏輯的代碼一定要抽出,可以參考面向對象的基類,前端開發中的面向組件編程、面向模塊編程也是這種思想

注釋&格式

每個人有每個人的習慣,采取一些通用準則即可,畢竟如何太過離譜在公司是會挨打的~

錯誤處理

也沒有什么固定的章程,最好采取try...catch優先的原則

邊界

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

單元測試

現在的互聯網企業絕大多數都是敏捷式開發,很少有能遵守測試驅動原則的公司,而且為了保證進度很少會有技術團隊會去要求單元測試,所以這一條仁者見仁吧,個人認為這一項的實際實現只能是一個比較美好的愿景。

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

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

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

二、單一權責原則(SPR):類或模塊應有且只有一條加以修改的理由,實現了這個原則的類更易得到復用

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

四、開放封閉原則(OCP):類應當對擴展開放,對修改封閉,通過子類化手段可以實現新功能的添加的同時不觸及其他類

五、依賴倒置原則(DIP):類應當依賴于抽象而不是依賴于具體細節

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

系統

一、構造和使用分開:構造的細節應隔離與應用程序代碼之外,使用者只能獲取構造者想讓使用者獲得的東西

二、設計時要能滿足從簡單到復雜的更新迭代

迭進

總結上述,只要遵守以下原則,就可以得到一個具有良好設計的可迭進的程序:

運行所有測試

不可重復

表達了程序員的意圖

盡可能減少類和方法的數量

以上規則按重要程度排列

并發編程

首先要了解“線程”這個概念:CPU調度的最小單位,區別于“進程”是資源分配的最小單位。區別見下方表格:

分類 數據共享 消耗資源 是否影響兄弟程序 最大可擴展維度 是否有鎖
進程 多機
線程 簡單 可能影響所在進程 多核

如果說對象是過程的抽象,那么線程是調度的抽象

前端使用的js語言是瀏覽器腳本語言,最主要的用途是和用戶互動和操作DOM,這決定了js只能是單線程否則會產生復雜的同步問題,但是js仍然可以模擬并發執行,具體實現自行查詢相關資料

當前還沒學習到并發編程的語言,以后碰到再補充學習

重構

這個模塊我認為是最重要的模塊,甚至比怎么去編寫新的程序更重要,因為一個公司的沉積項目的數量是巨大的,很可能會對其中幾個甚至更多進行重構(還是因為之前代碼寫的太爛無法維護),所以重構中需要注意的點也要有一個清晰的認知。

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

寫在最后

以上是我從前端角度總結的從這本書中得到的一些收獲,但是每個人都會有每個人自己的理解,所以還是推薦自己去讀一遍這本書,不需要多精細只要熟悉一下這些概念提出來的場景,相信會有更大的收獲。






審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • SPR
    SPR
    +關注

    關注

    0

    文章

    20

    瀏覽量

    11754
  • DIP
    DIP
    +關注

    關注

    0

    文章

    255

    瀏覽量

    31963
  • OCP
    OCP
    +關注

    關注

    0

    文章

    83

    瀏覽量

    17080
  • DOM
    DOM
    +關注

    關注

    0

    文章

    18

    瀏覽量

    9854

原文標題:常說的代碼整潔到底是什么?

文章出處:【微信號:eng2mot,微信公眾號:汽車ECU開發】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    AI代碼之爭忽略了什么

    人工智能的興起讓 COBOL 重新成為話題焦點,市場上也涌現出不少號稱能轉換遺留代碼、破解現代化難題的工具。但關鍵在于厘清這究竟意味著什么,以及它不包含什么。代碼轉換是一回事,平臺現代化則完全是另一碼事。這兩者并非同一概念,而橫亙其間的鴻溝,恰恰是大多數企業遇到麻煩的地方
    的頭像 發表于 03-02 15:20 ?293次閱讀

    分析嵌入式軟件代碼的漏洞-代碼注入

    隨著互聯網的發展,嵌入式設備正分布在一個充滿可以被攻擊者利用的源代碼級安全漏洞的環境中。 因此,嵌入式軟件開發人員應該了解不同類型的安全漏洞——特別是代碼注入。 術語“代碼注入”意味著對程序的常規
    發表于 12-22 12:53

    電力調整器常見故障代碼

    電力調整器(又稱晶閘管調功器)的故障代碼因品牌和型號而異,沒有一個完全統一的標準,但核心的保護功能是相似的。下表為你整理了合泉TM三相系列不同編碼系統中常見的故障代碼及其含義。
    的頭像 發表于 12-16 09:41 ?455次閱讀
    電力調整器常見故障<b class='flag-5'>代碼</b>

    HarmonyOS應用代碼混淆技術方案

    代碼混淆技術可以增加代碼的復雜性和模糊性,從而提高攻擊者分析代碼的難度。
    的頭像 發表于 11-21 16:17 ?5604次閱讀
    HarmonyOS應用<b class='flag-5'>代碼</b>混淆技術方案

    代碼開發平臺推薦:2025國內低代碼開發平臺排名TOP10

    代碼開發平臺排行榜 在企業數字化轉型的浪潮中,低代碼開發平臺正逐漸成為企業實現高效開發和快速迭代的重要工具。隨著技術的不斷進步和市場需求的持續增長,低代碼開發平臺的市場競爭也日益激烈。以下
    的頭像 發表于 10-28 10:22 ?733次閱讀

    2025主流低代碼平臺有哪些:低代碼開發平臺選型指南指南

    在企業數字化轉型進入深水區的當下,低代碼開發平臺已從早期的“效率工具”升級為“核心基建”。其工程化能力、流程適配深度、技術延展性與行業積淀,直接決定了企業轉型的成效。據Gartner預測,到2026
    的頭像 發表于 10-22 11:49 ?400次閱讀

    外殼防護等級(IP代碼)全解讀

    什么是外殼防護等級(IP代碼)IP代碼,全稱為“國際防護等級”,是由國際電工委員會制定的全球通用標準。這一標準旨在為電子設備外殼的防護能力提供一個清晰、統一的評判體系。簡單來說,IP代碼就是電子設備
    的頭像 發表于 10-14 12:13 ?1195次閱讀
    外殼防護等級(IP<b class='flag-5'>代碼</b>)全解讀

    代碼開發云平臺是什么?零編程零成本搭建

    代碼物聯網云平臺是種融合了低代碼開發能力與物聯網(IoT)技術的云端服務平臺,其核心目標是大幅降低物聯網應用的開發門檻和成本,讓用戶無需專業編程經驗,也能快速構建、部署和管理物聯網系統。 低代碼
    的頭像 發表于 07-31 15:25 ?757次閱讀

    Ansible代碼上線項目實戰案例

    在DevOps浪潮中,自動化部署已經成為每個運維工程師的必備技能。今天我將分享一個完整的Ansible代碼上線項目實戰案例,讓你的部署效率提升10倍!
    的頭像 發表于 07-24 14:03 ?580次閱讀

    單模光纜型號字母代碼及其含義

    單模光纜的型號字母代碼主要用于標識光纜的分類、結構、護層及光纖類型等關鍵信息,以下是一些常見的單模光纜型號字母代碼及其含義: 一、光纜分類代碼 GY:通信用室外光纜,這是最常見的室外光纜分類
    的頭像 發表于 07-17 10:27 ?3100次閱讀

    代碼革命的先鋒:aiXcoder-7B模型介紹

    ? ? 國內開源代碼大模型 4月9日aiXcoder宣布正式開源其7B模型Base版,僅僅過去一個禮拜,aiXcoder-7B在軟件源代碼托管服務平臺GitHub上的Star數已超過2k。同時躋身
    的頭像 發表于 05-20 14:41 ?803次閱讀
    <b class='flag-5'>代碼</b>革命的先鋒:aiXcoder-7B模型介紹

    OLED代碼分享

    OLED代碼
    發表于 04-29 17:04 ?1次下載

    變頻器相同的故障原因不同的故障代碼分類

    變頻器相同的故障原因可能對應不同的故障代碼,這主要取決于變頻器的型號、制造商以及具體的故障檢測機制。以下是一些常見的故障原因及其可能對應的不同故障代碼分類: 一、過電流故障 ● 故障原因:電動機銘牌
    的頭像 發表于 04-25 14:31 ?2543次閱讀
    變頻器相同的故障原因不同的故障<b class='flag-5'>代碼</b>分類

    【JVM開發者必看】IntelliJ IDEA代碼分析實踐指南:實時糾錯、冗余檢測、自動修復等

    【IntelliJ IDEA中的代碼分析技巧】靜態代碼分析是指在不實際運行代碼的情況下掃描代碼以發現潛在問題。IntelliJ IDEA中的檢查可以在您編譯項目之前檢測到其中的潛在問題
    的頭像 發表于 03-13 10:34 ?1066次閱讀
    【JVM開發者必看】IntelliJ IDEA<b class='flag-5'>代碼</b>分析實踐指南:實時糾錯、冗余檢測、自動修復等

    貼片電感的感值代碼與讀取方法

    貼片電感作為電子電路中的重要元件,其感值的準確性和讀取方法的便捷性對于電路的性能至關重要。本文將詳細介紹貼片電感的感值代碼及其讀取方法。 貼片電感的感值代碼通常采用數碼表示法,這種方法通過特定的數字
    的頭像 發表于 03-06 14:15 ?1837次閱讀
    貼片電感的感值<b class='flag-5'>代碼</b>與讀取方法