代碼整潔一

来源:https://www.cnblogs.com/ksh-xy/archive/2018/11/25/10016966.html
-Advertisement-
Play Games

什麼是代碼整潔 今天來說說“代碼整潔”,這是個永恆的話題,自從第一行代碼被寫出來後,優秀的程式員們就不停地通過各種方法、方式和工具來使自己的代碼看來整潔美觀。那為什麼我們要做代碼整潔?不管你做過幾年編程,你一定被某個傻缺的糟糕代碼絆倒過氣的找不到北;同時自己也肯定寫過這種代碼把別人坑的不要不要的,讓 ...


什麼是代碼整潔

    今天來說說“代碼整潔”,這是個永恆的話題,自從第一行代碼被寫出來後,優秀的程式員們就不停地通過各種方法、方式和工具來使自己的代碼看來整潔美觀。那為什麼我們要做代碼整潔?不管你做過幾年編程,你一定被某個傻缺的糟糕代碼絆倒過氣的找不到北;同時自己也肯定寫過這種代碼把別人坑的不要不要的,讓人指著後脊梁骨暗罵一通。毛主席講過批評與自我批評,人總是在自我檢討中成長,所以就先來讓我們先看看代碼混亂主要的幾種原因(各種案例在下一章列出):

  • l  混亂的格式排版,各種風格寫法
  • l  文不對意的表達式(變數、函數、屬性等等)
  • l  毫無註釋的白板代碼;
  • l  麵條式函數,職責功能混雜在一起;
  • l  邏輯混亂的代碼;
  • l  僵屍代碼,無效代碼,無數個參數的函數;
  • l  ....(希望大家補充)

    如果你一直都是寫出上面所描述的混亂不堪的代碼,不僅得不到同事的尊重,自己你的編碼水平也不會隨著時間推移而提升,更容易成為N年工作經驗,混亂不堪的代碼更是將項目推向難以維護的境地。所以從個人角度上說,整潔好看的代碼不僅是你技術水平體現更能讓你贏得大家的尊重;從項目角度上說,整潔優秀的代碼是產品可維護性基石,整潔有序的代碼是任何產品失控之前的第一道防線;所以優秀整潔的代碼在公在私都極為重要,鑒於以上原因我將代碼整潔作為我們分享會第一課,就是趁在座各位都還處於代碼嬰兒階段,讓大家養好習慣、打好基礎、培養好自己的代碼思想力為你們日後成為代碼大師打下最堅實的基礎。

最後,將美國童子軍的一條簡單軍規應用到我們的專業領域:“讓營地比你來的時候更乾凈。”--《代碼整潔之道》

怎麼樣做才是代碼整潔

灌了這麼多心靈雞湯,那麼我們怎麼做好代碼整潔,在我看來有兩個方面:

一、調整心態

你是否在寫代碼時,是否有下麵心理狀態:

  •  “進度來不及,這個後面再優化吧,先把功能實現了”,若幹年後,你會看到這段代碼依然活著,註釋依然還在;
  • “重構太麻煩了,這段代碼還是copy一份,到我自己文件裡面去吧,重覆就重覆吧”,若幹年後,你會看到到處都是一模一樣的代碼;
  • “這麼垃圾代碼,不是我寫的我才懶的改, 反正它運行的就行了”,總有一天你會繞不開它被它坑一次;
  •  “我英文不行,變數名隨便下,aabb,文件名隨便定下”,若幹年後,你會發現自己都找不到這個文件;

上述原因,跟任何技術水平有關嗎?

   無關,全部都是心態上的問題,所以提高代碼整潔第一步就是需要提高自我責任心不斷的心理暗示告訴自己需要對自己的代碼負責,如何寫的更好看一些,如何讓別人更容易讀懂一些,需要你有處女座般的潔癖來打造自己的代碼

二、硬性技能

1. 有意義的命名

代碼中隨處可見命名。我們給變數、函數、參數、類和文件命名。我們寫代碼30%都在命名, 選個好名字要花時間,但省下來的時間比花掉的多。而且一旦發現有更好的名稱,就替換掉舊的。這麼做,讀你代碼的人(包括你自己)都會更開心?下文舊列出幾條簡單規則(本文不是討論具體代碼規範,因為有太多太多內容可以談,所以將以概念為主)。

1.1 名副其實的名稱

如下圖一,簡潔且格式代碼也符合.net標準。但是你能知道它做什麼嗎?

 

主要有3個問題:一、函數名不知道做什麼;二、函數參數不知道傳入什麼、三、使用字面量。歸結起來,按專業的說法:簡潔度達標,但是模糊度太高,無法見文知意。

我們先看調整後的代碼格式

    這裡,我們做了幾個修改,可以很明顯看到效果:

  1. 變數名,不要再使用list,使用具體作用含義;
  2. 使用“魔法數”,不使用“字面量”,將“4”使用變數代替

1.2 一致的拼寫,避免誤導

當你在設計API,編寫業務層代碼時,沒有絕對的標準,但是請與舊代碼保持一致性。舉個例子:

正例:

GetOrganByOrgid(string orgId)

GetOrganByParentId(string parentID)

GetOrganByOrgEntity(Organ entity);

反例:

  GetOrganData(string orgId)

  LoadOrganByOrgList(Organ entity)

  LoadOrganUseParentId(string parentID)

現代化的IDE的智能感知已經非常先進,很多程式員已經不看介面文檔,如果一致的拼寫,在IDE智能感知了,就非常方便開發人員調用; 

1.3 做有意義的區分

    1.3.1 不要以數字系列命名,例如a1,a2…aN。如下反例:

Public DataTable GetCostListByUserDate(DateTime date1,DateTime date2);

但是這樣,完全無法體現出來參數的作用及作者意圖,正例:

Public DataTable GetCostListByUserDate(DateTime startTime,DateTime endTime);

    1.3.2 不要添加廢話修飾

        不要加上,Info ,Data ,the 這些廢話定詞

        例如: AccountInfo、AccountData與 Account 。其實代表一樣的含義;

        再比如,

1.4 使用可搜索的名稱

    同1.1中的魔法術,這點是最容易改進的,搜索“4”容易還是搜索”CHECK_FLAG”容易?

1.5 避免使用編碼,首碼

    在遠古時代,因為IDE還不流行。需要在變數名前,加首碼;例如 b_ 代表byte.i_ 代碼表int類型;但是現在IDE已經非常流行了,無需再加這些首碼;

1.6 類名方法名

    類名、變數名應該是名詞短語,例如: Account,Page,Customer等。

    方法名,應該是動詞短語,例如:GetAccount,DownLoadPage

1.7改善措施:

學習英語(我老大上市公司研發部總監,依然每天朋友圈打卡學習英語,開始學習吧,沒人笑你!這是你日後職場上的最重要武器之一 )

常用詞列表(會隨著部門代碼規範一起發佈)

2. 一致性的格式

2.1 團隊規則

每個coder都有自己喜歡的格式規則,但是如果在一個團隊中,就應該團隊說了算。而不是讓它顯得有一大票意見相做的個人所寫成。

我們的措施:.Net代碼規範(自定義 + StyleCop.Analyzers )

Javascript:代碼規範(需要大家群策群力)

2.2 垂直格式

向報紙學習,源文件也要像報紙文章那樣。名稱應當簡單而且一目瞭然。源文件最頂部應該給出高層次的概念和演算法。細節應該往下漸次展開,直到源文件中的最底層函數和細節。

例如:

.Net中,類中的全局變數,私有變數,常量等等,均放在類中最頂部

函數方法,public , protect private,按順序擺放。

JavaScript中,全局變數,私有變數,常量等等,均放在類中最頂部

2.3 橫向格式

  我剛工作時,當時的代碼規範是橫向建議一行最多不超過80個字元。隨著近年顯示器越來越大,一行大家都預設不超過120個字元原則,但是不管什麼樣顯示,我們保持無橫向滾動條原則。

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、MyBatis MyBatis 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,並且改名為MyBatis 。2013年11月遷移到Github。 iBATIS一詞來源於“internet”和“ ...
  • 在上一篇文章中,我們介紹了 Python 的函數式編程,現在我們介紹 Python 的類和繼承。 查看上一篇文章請點擊:https://www.cnblogs.com/dustman/p/10010690.html 類先前,我們研究過兩種編程範式--命令式(使用語句、迴圈和函數)和函數(使用純函數、 ...
  • 背景 ​ Spring Cloud現在已經被越來越多的公司採用了,微服務架構比傳統意義上的單服務架構從複雜度上多了很多,出現了很多複雜的場景。比如,我們的產品是個app,支持第三方登錄功能,在手機端調用第三方授權介面之後,返回了用戶的相關信息,比如open_id,性別,頭像等。這些信息我們需要保存在 ...
  • Python基礎知識(13):函數(Ⅳ) Python內置函數 1、abs:取絕對值 2、all:把序列中的每一個元素拿出來做布爾運算,都為真則返回True,如果序列中有None、0、“”、[]、{}、()則返回False 3、any:只要序列中有一個元素做布爾運算後的值為真,就返回True 4、a ...
  • 在WPF或者UWP應用開發中,有時候會不可避免的需要操作文件系統(創建文件/目錄),這時候有幾個坑是需要大家註意下的。 創建文件或目錄時的非法字元檢測 在Windows系統中,我們創建文件時會註意到,某些特殊字元是不可以用作文件名輸入的。 那麼,同樣的,如果你的應用可以提供給用戶創建文件/目錄的功能 ...
  • 從開發者社區看,Asp.Net Core 有多火熱,那麼在過去 10 年間,C# 的開發者就有多壓抑,過去 10 年以來,以 C# 開發語言為主業的開發者,幾乎只能游歷於所謂的企業級開發,其實就是做 OA、ERP、CRM 等傳統軟體開發,或者服務於部分互聯網公司的內部管理系統;從業務層面來說,他們從... ...
  • 兩段極為相似的代碼,主要想看看過輸與序列化過程兩者的用時差異,結果10000次的調用,WCF用了11秒多,remoting用了5秒不到!這是測試的源代碼 WCF的服務端 Remoting的服務端 代碼可以理解為一樣的,以下的客戶端,兩客戶端也可以視為一樣的過程WCF客戶端 Remoting客戶端 ...
  • 如果你使用命令: PM> add-migration Inital 提示如下信息時: The EF Core tools version '2.1.1-rtm-30846' is older than that of the runtime '2.1.4-rtm-31024' 解決方法大致一下幾種: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...