dotnet core 編程規範

来源:https://www.cnblogs.com/lindexi/archive/2018/05/30/9108967.html
-Advertisement-
Play Games

本文實際只是翻譯 .NET Core foundational libraries 官方文檔的編碼風格 ...


本文實際只是翻譯 .NET Core foundational libraries 官方文檔的編碼風格

.NET Core foundational libraries項目使用的編程規範預設就是 VisualStudio 預設樣式。

花括弧

花括弧使用 Allman style 風格,所有的花括弧在新的一行開始。

關於 Allman style 就是如下,花括弧放在下一行,而且花括弧不進行縮進,花括弧裡面的代碼縮進。

while (x == y)
{
    something();
    somethingelse();
}

但是對於單行的語句,可以不添加花括弧,但是請把它放在同一行

          if (xx == null) xx = new Foo();

單行語句同樣建議添加花括弧避免蘋果的bug

如果不添加花括弧,一定不要在嵌套時使用。

空格

使用 4 個空格作為一個縮進,而不是使用 tab

欄位

所有的欄位使用_camelCase風格,而且儘可能使用readonly。在 internal 和 private 訪問的欄位添加 _ 首碼,對於靜態的欄位添加s_首碼,對於線程靜態的欄位添加t_首碼。如果使用了靜態的欄位而且可以設置readonly,需要把readonly放在static後面。

最好不要公開欄位,如果需要公開那麼使用PascalCasing風格而且不添加首碼。

我不是很贊同對欄位的風格,但是因為本文是翻譯,我就沒有添加自己的理解。

限定

不要添加 this. ,完全是沒必要的。

我也不是很贊同這個,因為如果使用擴展方法,需要使用this.

訪問

顯示指定訪問,即使訪問是預設的,如private string _foo ,而不是string _foo。訪問需要放在最前面,如public abstract,不建議abstract public

預設的訪問是可能修改的

命名空間

對於引用需要放在文件的開頭。

空行

禁止超過一行的空白,不可以使用兩行空白。

不要使用兩行分割兩個類型。

多餘空格

禁止在一行結束添加多餘空格。通過 VisualStudio 的查看空格(ctrl+E,S)可以看到空格

參照現有

如果一個文件在格式規範定義之前已經有自己的規範,儘可能參照文件現有的規範而不是去修改他。

新的修改參照現有的文件的格式。

我一點都不贊同。

明顯的類型

只能在明顯可以知道對象類型可以使用 var ,如var stream = new FileStream(...) 。在無法明顯知道對象類型不可以使用 var ,如var stream = OpenStandardInput()

關鍵字

使用語言的關鍵字代替 BCL 類型,如使用 int, string, float代替Int32StringSingle

常量命名

對於所有的常量,包括靜態只讀,使用 PascalCasing 風格。如果需要使用 C++ 或其他代碼對於命名有要求才可以使用其他的方法。

變數名字元串

如果使用變數名的常量,必須使用 nameof 關鍵字。

欄位結構

欄位必須放在一個類聲明的最前面。

我一點都不贊成,因為誰會去管一個類的欄位,我關心的是構造函數和公開屬性、函數。

其他字元

如果在代碼使用了 非 ascii 的字元,那麼需要把他轉換為 \uxx 方式,這樣可以解決一些非 ascii 因為編譯器分析的問題。

當然上面的要求只是對於編譯的代碼

Label

使用 Label 縮進一個小於當前縮進的標簽

原文:coding-style.md

dotnet core 編程規範 - CSDN博客

知識共用許可協議
本作品採用知識共用署名-非商業性使用-相同方式共用 4.0 國際許可協議進行許可。歡迎轉載、使用、重新發佈,但務必保留文章署名林德熙(包含鏈接:http://blog.csdn.net/lindexi_gd ),不得用於商業目的,基於本文修改後的作品務必以相同的許可發佈。如有任何疑問,請與我聯繫


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

-Advertisement-
Play Games
更多相關文章
  • 對於非線性的鏈表,可以參見相關的其他數據結構,例如樹、圖。另外有一種基於多個線性鏈表的數據結構:跳錶,插入、刪除和查找等基本操作的速度可以達到O(nlogn),和平衡二叉樹一樣。 ...
  • lock free ...
  • const 標識符 在c++中作為常量修飾符 用來修飾 函數 變數 指針 const 修飾的變數不可以改變值 const 在修飾指針的時候 const 標識符出現在*的左邊表示 指向的變數為常量不能通過指針去改變該對象的值 叫做常量指針即const int a = 0; const int* ipt ...
  • 坐標南京 211 cs專業 工作經驗算上實習1年多,外包公司,員工各種離職,項目越做越難,工資不漲怒而離職。目前陷入找工作的泥潭,記錄一些知識點的不足來督促自己吧。 2018/5/29 zn公司 : 很棒的公司,環境好,員工都是年輕人,大牛很隨和,問了很多題目,回答上來一部分,還答錯了一部分。 1、 ...
  • 字典的key是一個可哈希的值,字典的value可以是任何值。 keys():返回鍵 values():返回鍵對應的值 items():返回鍵和值 keys遍歷出來 values遍歷出來 items遍歷出來 get():根據key獲取值,key不存在時,可以指定預設值(None) pop() popi ...
  • 本文來告訴大家一個新的技術DirectComposition,在 win7 之後(實際上是 vista),微軟正在考慮一個新的渲染機制 ...
  • 本文告訴大家如何使用 Marshal 做出可以快速釋放記憶體的大數組。 最近在做 3D ,需要不斷申請一段大記憶體數組,然後就釋放他,但是 C# 對於大記憶體不是立刻釋放,所以就存在一定的性能問題。 在博客園看到了一位大神使用 Marshal 做出快速申請的大數組,於是我就學他的方法來弄一個。本文告訴大... ...
  • 如果在 WPF 需要用多進程通信,一個推薦的方法是 WCF ,因為 WCF 是 RPC 計算。先來講下 RPC (Remote Procedure Call) 遠程過程調用,他是通過特定協議,包括 tcp 、http 等對其他進程進行調用的技術 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...