提高代碼的可讀性

来源:https://www.cnblogs.com/yujinhu/archive/2018/10/04/9742884.html
-Advertisement-
Play Games

提高代碼的可讀性,不僅方便自己以後閱讀,而且可以讓後來的人更好閱讀你的代碼,最近一直在積累這方面的知識,以後嚴格遵循這種寫法,做到“有法可依”,有更好的寫法待用到之時再進行更新補充,在這裡做一下筆記。 1.註釋和文檔 這裡有一個技巧,可以方法的上面連續敲擊三下"/",就可以自動補充,寫對應的註釋,無 ...


提高代碼的可讀性,不僅方便自己以後閱讀,而且可以讓後來的人更好閱讀你的代碼,最近一直在積累這方面的知識,以後嚴格遵循這種寫法,做到“有法可依”,有更好的寫法待用到之時再進行更新補充,在這裡做一下筆記。

1.註釋和文檔

這裡有一個技巧,可以方法的上面連續敲擊三下"/",就可以自動補充,寫對應的註釋,無論是js還是C#,在寫代碼之前,都要先進行寫註釋,採用動賓結構,如:“獲取用戶信息”,“添加用戶信息”。陳述方法的做了什麼事,言簡意賅,當然良好的命名規範易讀性更好。

    /// <summary>
    /// 在這裡寫註釋
    /// </summary>
    /// <param name="param"></param>
    /// <returns></returns>
    public ActionResult Index(string param)
    {
        return View();
    }

2.代碼分組

為了讓代碼的可讀性更好,可以對代碼進行分組,儘量讓同一邏輯放在同一組,即用換行隔開。

        //計算還款金額
        var repayMoney = (from h in db.JF_FIN_REPAY
                          where h.CLIENTID == bpid
                              && h.STATE == (int)FinancingEnum.FinRepayState.還款成功
                              && h.ORDERTYPE == ((int)FinOrderType.還款單).ToString()
                              && h.FINANCETYPE == ((int)FinOrderType.提貨款).ToString()
                          select h.REPAYTOTALMONEY).Sum();

        if (Request["state"] = "已保存")
        {
            ///...
        }
        if (true)
        {
            ///...
        }

3.保持一致的命名規範

命名規範,我強制使用駝峰式和帕斯卡命名規範,當然使用其他的也是可以的,沒有問題的,主要習慣便可以,但是必須保持一致,js,C#的代碼的命名規範都要使用駝峰式或帕斯卡命名,C#和js命名有所不同,對應使用即可,如:
js:

//獲取用戶信息
function getUserInfo() {
    ///...
}

C#:

    /// <summary>
    /// 獲取用戶信息
    /// </summary>
    public void GetUserInfo()
    {
        ///...
    }

4.DRY原則(摘錄於阮一峰博客)

DRY是 Don't repeat yourself 的縮寫,意思是"不要重覆自己"。

軟體工程名著《The Pragmatic Programmer》首先提出了這個原則。它的涵義是,系統的每一個功能都應該有唯一的實現。也就是說,如果多次遇到同樣的問題,就應該抽象出一個共同的解決方法,不要重覆開發同樣的功能。

這個原則有時也稱為"一次且僅一次"原則(Once and Only Once)。

如果多次遇到同一問題,就應該將對應的方法進行抽象,進行封裝,便於以後重覆使用,對於一些常用的公共類或者方法可以進行積累,保存於GitHub的項目中等,保存起來便於以後拿取,最近新建了一個項目,對曾經做過的一些公共的、可以抽象封裝的方法等進行積累,避免重覆開發,以後這就是經驗。

5.避免深嵌套

過多的嵌套會極大降低代碼的可讀性:

//獲取用戶信息
function getUserInfo() {
    ///...
    if (true) {
        if (true) {
            if (true) {
            ///..
            }
        }
    }
}

儘量減少代碼嵌套,不多於兩層:

//獲取用戶信息
function getUserInfo() {
    ///...
    if (true) {
        ///..
    }
    if (true) {
        ///..
    }
    if (true) {
        ///...
    }
}

6.限制行長度

行長度過長也是會極大降低代碼的可讀性:

        //計算還款金額
        var repayMoney = (from h in db.JF_FIN_REPAY
                          where h.CLIENTID == bpid && h.STATE == (int)FinancingEnum.FinRepayState.還款成功 && h.ORDERTYPE == ((int)FinOrderType.還款單).ToString() && h.FINANCETYPE == ((int)FinOrderType.提貨款).ToString()
                          select h.REPAYTOTALMONEY).Sum();

可以針對一致的特殊“符號”進行換行,如,“&&”,“||”,“,”等:

        //計算還款金額
        var repayMoney = (from h in db.JF_FIN_REPAY
                          where h.CLIENTID == bpid
                              && h.STATE == (int)FinancingEnum.FinRepayState.還款成功
                              && h.ORDERTYPE == ((int)FinOrderType.還款單).ToString()
                              && h.FINANCETYPE == ((int)FinOrderType.提貨款).ToString()
                          select h.REPAYTOTALMONEY).Sum();

7.參數值的命名

對於一些參數的值,有時我們需要對一些數據進行區別,就會使用不同的參數值,進行傳遞,這時候,使用的參數值,如果是一些無意義的值,就會增加代碼的閱讀的難度:

        if (Request["state"] = "1")
        {
            ///...
        }

可以使用一些有意義的名稱保存,中文或者英文,切忌使用一些無意義的數字、字母,使用硬編碼使代碼易讀性更好:

        if (Request["state"] = "已保存")
        {
            ///...
        }

8.避免寫新代碼

在做一個新功能的時候,可以思考,別人是否已經實現這個功能,有沒有工具,函數等已經實現你想要的功能,可以從網上查找或問同事是否已經實現對應的功能,避免盲目重覆造輪子,代碼越少,bug越少。

The best code is the code that isn’t written ”

9.局部變數的命名

這是一個讓我糾結很久的話題,很多人都有不同的命名習慣,也不能說誰的好,誰的不好,把一些固定的用法,按照自己的習慣進行規範:

        //Array尾碼的數組變數 
        Object[] arr = ...;

        //使用類型的縮寫 
        DataTable dt = ...;

        //變數的聲明,類型儘量使用介面,這樣對於修改實現容易 
        IList lst = new ArrayList();

        //flag是一個常用的變數 
        bool flag = false;

        //item也是一個常用的命名 
        foreach (Object item in lst)
        {
            if (flag)
            {
                Console.Write(",");
            }

            flag = true;  //flag之前有一個空行,代碼中應有恰當的分行 
        }

        //使用符合短語對變數命名 
        String name = obj.GetType().GetName();  

參考:
https://www.cnblogs.com/jobs/archive/2004/07/22/26341.html#26355
http://news.51cto.com/art/201708/549819.htm
http://news.51cto.com/art/201710/554067.htm


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

-Advertisement-
Play Games
更多相關文章
  • 第一個SpringBoot程式 例子來自慕課網廖師兄的免費課程 "2小時學會SpringBoot" "Spring Boot進階之Web進階" 使用IDEA新建工程,選擇SpringBoot Initializr,勾選Web一路next就搭建了一個最簡單的SpringBoot工程。如下: @Spri ...
  • 基本概念 JMX(Java Management Extensions,即Java管理擴展)是一個為應用程式、設備、系統等植入管理功能的框架。JMX可以跨越一系列異構操作系統平臺、系統體繫結構和網路傳輸協議,靈活的開發無縫集成的系統、網路和服務管理應用。簡介看上去不是很直觀和明白,也可能我瞭解的太少 ...
  • 輸出結果:main start t1 -> main wait() -> t1 call notify() -> main continue 其實調用t1.start(),t1為就緒狀態,只是main方法中,t1被main線程鎖住了,t1.wait()的時候,讓當前線程等待,其實是讓main線程等待 ...
  • 1. 在urls.py的文件中導入操作正則表達式的方法:(新版的Django是使用path方法對URL進行路由分配) 2 . 在templates文件夾下的index.html添加如下代碼,進行路徑匹配:(在需要超鏈接的連接進行路由匹配) 3. 點擊超鏈接顯示的URL如下: http://127.0 ...
  • #1831 : 80 Days #1831 : 80 Days 時間限制:1000ms 單點時限:1000ms 記憶體限制:256MB 描述 80 Days is an interesting game based on Jules Verne's science fiction "Around th ...
  • JDK 11 ZGC簡介 註1:本文翻譯自這篇 "文章" 註2: 我有了新的獨立博客 "地址" ,歡迎訪問 前言 ZGC是最近由Oracle為OpenJDK開源的新垃圾收集器。它主要由Per Liden編寫。ZGC類似於 "Shenandoah" 或Azul的C4,專註於減少暫停時間的同時仍然 "壓 ...
  • 在web.config 的configuration節點下添加 <runtime> <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1"> <dependentAssembly> <assemblyIdentity name="Newto ...
  • 通過ASP.NET MVC 完成一個具有註冊登陸和發佈帖子的功能的網站。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...