建立标准编码规则(四)-C#编码规范分类及实现
1 现实中的问题
在任何一个公司,每个程序员编写的习惯可能都是不一样的,大到命名空间,小到变量的名字。甚至,我们去github,里面的大牛每个开源的项目的命名规则可能都不一样。
我们通常会遇到下面的问题
1 一个webapi,版本1是一种写法,版本2认知到版本1的写法过于老旧又换了一种写法
2 一个webapi,程序员老王习惯返回大写,程序员小张喜欢返回小写
3 各个业务类似的webapi,名字都不相同,例如供应商有的用vendor 有的用supplier 有的干脆用拼音
4 公司有实际的编码规范,但检测成本太高,久而久之,公司的规范也就作废了
5 数据库规范、编码规范、api规范可能不尽相同,有冲突,制造了转换成本
这实际上会给我们增加沟通成本,当遇到bug的时候,代价是巨大的。
前段实际阿里发布了java规范,可谓行业标杆,微软为啥就没有发布一个可推广的编码规范呢。
2 编码规范的目的及基本情况
我认为编码规范的目的是为了使代码不依赖与代码编写者而存在。就是无限增加代码的可读性,易维护性。
我们不光要考虑程序代码的可读性还要考虑
1 数据库的可读性
2 程序代码的可读性
3 对外开放的api可读性
这三种情况的业务场景对代码规范又不尽相同。
数据库
数据库因为受限于数据库软件,需要强制对数据库命名进行约束
SQL SERVER数据库,目前在windows上已知的是没有什么大小写限制,在Linux上未知没有试过
mysql 数据库,推荐全部小写,英文之间加下划线_,例如 useraddress 表示为user_address
oracle数据库,推荐全部大写,因为之间加下划线_,例如useraddress表示为 USER_ADDRESS
程序编码
C# 基本上 类名UpperCamelCase,公共方法 UpperCamelCase 私有方法 LowerCamelCase
对外的API
json一般建议是的 小写,下划线写法
xml到时没有什么特定的规范
我们这里要讨论的是,这三种如何统一,如何转换的问题
3 如何保证编码规范的可执行性
任何脱离可执行的规范文件都是耍流氓
1.数据库,我们可以编写程序遍历数据库,检测是否合规
2.代码,可以使用Roslyn编写分析器
4 C#代码规范
C#代码规范可以参考StyleCop做简单的说明,一共171条规则,新版已经删除了部分规则并新增了部分规则。一个规则可能有多个代码分析器,所以实际上是看起来很多而已。
我们可以下载源码对其进行修改编辑,形成自己公司的代码规范。
SA1600 ElementsMustBeDocumented 元素必须添加注释
SA1601 PartialElementsMustBeDocumented Partial修饰的成员必须添加注释
SA1602 EnumerationItemsMustBeDocumented 枚举必须添加注释
SA1603 DocumentationMustContainValidXml 注释必须合法(注释中的关键字不能有错误)
SA1604 ElementDocumentationMustHaveSummary 元素注释必须包含Summary关键字
SA1605 PartialElementDocumentationMustHaveSummary Partial修饰的成员注释必须包含Summary关键字
SA1606 ElementDocumentationMustHaveSummaryText Summary节点内部必须添加文本
SA1607 PartialElementDocumentationMustHaveSummaryText Partial修饰的成员注释Summary节点内部必须添加文本
SA1608 ElementDocumentationMustNotHaveDefaultSummary Summary注释不能使用编译器自带的注释文本
SA1609 PropertyDocumentationMustHaveValue 属性的注释中必须包含<Value>节点
SA1610 PropertyDocumentationMustHaveValueText 属性的注释<Value>节点必须包含文本值
SA1611 ElementParametersMustBeDocumented 参数必须注释
SA1612 ElementParameterDocumentationMustMatchElementParameters 参数的个数必须与注释里的个数一致
SA1613 ElementParameterDocumentationMustDeclareParameterName 参数的注释里必须有参数的名称
SA1614 ElementParameterDocumentationMustHaveText 参数注释节点里不能空着
SA1615 ElementReturnValueMustBeDocumented 返回值必须添加注释
SA1616 ElementReturnValueDocumentationMustHaveText 返回值注释的节点内必须有文本值
SA1617 VoidReturnValueMustNotBeDocumented 空返回值一定不能有返回值注释
SA1618 GenericTypeParametersMustBeDocumented 生成的类型(泛型)参数必须有注释
SA1619 GenericTypeParametersMustBeDocumentedPartialClass SA1618情况如果有Partial类存在都要有注释
SA1625 ElementDocumentationMustNotBeCopiedAndPasted 各个参数的注解不能完全相同(避免copy
SA1626 SingleLineCommentsMustNotUseDocumentationStyleSlashes 单行注释不能采取三个斜线的注释方式,斜线的个数必须是二的倍数
SA1627 DocumentationTextMustNotBeEmpty 注释节点内部不能为空(必须有文本值)
SA1628 DocumentationTextMustBeginWithACapitalLetter 注释节点内部的文本必须以大写字母开头
SA1629 DocumentationTextMustEndWithAPeriod 注释节点内部的文本必须英文的句号结束
SA1630 DocumentationTextMustContainWhitespace 注释节点内部的文本必须包含空格
SA1631 DocumentationMustMeetCharacterPercentage 注释节点内部的文本中不能包含过多的字符(举例包含’---------------’是不允许的)
SA1632 DocumentationTextMustMeetMinimumCharacterLength 已经作废的规则,不允许有太短的字符串(如’Aname’中的A字母)
SA1642 ConstructorSummaryDocumentationMustBeginWithStandardText 构造函数注释标准
SA1643 DestructorSummaryDocumentationMustBeginWithStandardText 析构函数注释标准
SA1644 DocumentationHeadersMustNotContainBlankLines 注释中不能出现空白行
SA1645 IncludedDocumentationFileDoesNotExist 如果注释中包含文件,要确定这个文件存在,举例
SA1646 IncludedDocumentationXPathDoesNotExist 如果注释中包含文件,路径不存在。
SA1647 IncludeNodeDoesNotContainValidFileAndPath 如果注释中包含文件文件与路径都要合法
SA1648 InheritDocMustBeUsedWithInheritingClass 这项不明白是什么意思,还请知道的分享给我,谢谢。
SA1649 FileHeaderFileNameDocumentationMustMatchTypeName 文件头注释必须匹配类型
SA1650 ElementDocumentationMustBeSpelledCorrectly 注释不能有拼写错误(对中文支持不好,不建议使用该项)
SA1651 DoNotUsePlaceholderElements 不要使用Placeholder元素
SA1500 BracesForMultiLineStatementsMustNotShareLine 当存在多行程序的时候,花括号不能再同一行。
SA1501 StatementMustNotBeOnASingleLine 语句不能共享一行
SA1502 ElementMustNotBeOnASingleLine 元素不能共享一行
SA1503 BracesMustNotBeOmitted 花括弧即使在单行代码的情况下也不能省略。
SA1504 AllAccessorsMustBeSingleLineOrMultiLine 读写属性,要么在同一行业要么在分多行写,不可规则不统一(个人建议分多行写)。
SA1505 OpeningBracketsMustNotBeFollowedByBlankLine 开始的花括弧后面不能有空白行
SA1506 ElementDocumentationHeadersMustNotBeFollowedByBlankLine 元素头部注释跟元素之间不能有空白行
SA1507 CodeMustNotContainMultipleBlankLinesInARow 不允许有多行空白行紧挨着(个人建议写一个空白行即可)
SA1508 ClosingCurlyBracketsMustNotBePrecededByBlankLine 结尾的花括弧不能再一个空白行之前
SA1509 OpeningBracketsMustNotBePrecededByBlankLine 开始的花括弧不能再一个空白行之前
SA1510 ChainedStatementBlocksMustNotBePrecededByBlankLine 相连的语句之间不能有空白行,如
try
语句与
catch
语句之间不能有空白行
SA1511 WhileDoFooterMustNotBePrecededByBlankLine 与SA1510相同,Do语句与While语句之间不能有空白行
SA1512 SingleLineCommentsMustNotBeFollowedByBlankLine 单行注释不能后跟空白行
SA1513 ClosingBracketMustBeFollowedByBlankLine 结束花括弧之后必须有一个空白行
SA1514 ElementDocumentationHeaderMustBePrecededByBlankLine 头部注解之前必须有一个空白行
SA1515 SingleLineCommentMustBePrecededByBlankLine 单行注释之前要有一个空白行,还一种方法是不加空白行而用四个斜线注释”
////”建议采取第一种方法
SA1516 ElementsMustBeSeparatedByBlankLine 邻近的元素之间要有一个空白行
SA1517 CodeMustNotContainBlankLinesAtStartOfFile 代码文件头部字符之前不能出现空白行
SA1518 CodeMustNotContainBlankLinesAtEndOfFile 代码文件尾部字符之后不能出现空白行
SA1119 StatementMustNotUseUnnecessaryParenthesis 语句中不可以出现多余的括弧,无意义的括弧增加了代码的可读性
SA1400 AccessModifierMustBeDeclared 必须定义访问修饰符
SA1401 FieldsMustBePrivate 字段必须定义为私有的
SA1402 FileMayOnlyContainASingleClass 一个CS文件里只定义一个类
SA1403 FileMayOnlyContainASingleNamespace 一个CS文件只包含一个命名空间
SA1404 CodeAnalysisSuppressionMustHaveJustification Suppression特性(取消报告特定的静态分析工具规则冲突,允许一个代码项目上应用多个取消报告设置)必须要有合理理由
SA1405 DebugAssertMustProvideMessageText 参见代码:“Debug.Assert(value !=
true
"The value must always be true."
);”
SA1406 DebugFailMustProvideMessageText 参见代码:“Debug.Fail(
"The code should never reach this point."
);”
SA1407 ArithmeticExpressionsMustDeclarePrecedence 算数表达式必须用明确的标明其优先级(此条与SA1119冲突)
SA1408 ConditionalExpressionsMustDeclarePrecedence 条件表达式必须明确的标明其优先级(此条与SA1119冲突) 举例:“
if
(x || (y && z && a) || b)”
SA1409 RemoveUnnecessaryCode 移除无用的代码
SA1410 RemoveDelegateParenthesisWhenPossible 调用一个c#匿名方法不包含任何方法参数必须要包括一个空括号(本人不建议使用匿名方法
SA1411 AttributeConstructorMustNotUseUnnecessaryParenthesis 特性构造函数如果是空参的形式,不要包括那个空括号
SA1412 StoreFilesAsUtf8 文件是否已utf8格式存储
SA1413 UseTrailingCommasInMultiLineInitializers 初始化对象变量之间使用逗号隔开
SA1300 ElementMustBeginWithUpperCaseLetter 首字母必须大写(个人理解应该是字段以外的东西)
SA1301 ElementMustBeginWithLowerCaseLetter 不会出现的情况
SA1302 InterfaceNamesMustBeginWithI 接口必须以“I”字母开头
SA1303 ConstFieldNamesMustBeginWithUpperCaseLetter Const 常量首字母大写
SA1304 NonPrivateReadonlyFieldsMustBeginWithUpperCaseLetter 非私有非制度的字段必须首字母大写
SA1305 FieldNamesMustNotUseHungarianNotation 除了列表外的字符不可以出现匈牙利命名规则在”Style Setting”里的” Hungarian”Tab里设置
SA1306 FieldNamesMustBeginWithLowerCaseLetter 字段名必须首字母小写
SA1307 AccessibleFieldsMustBeginWithUpperCaseLetter
public
或者
internal
字段首字母大写
SA1308 VariableNamesMustNotBePrefixed 变量名不能有前缀
SA1309 FieldNamesMustNotBeginWithUnderscore 字段名不能以下滑线开头
SA1310 FieldNamesMustNotContainUnderscore 字段名不能包括下滑线
SA1311 StaticReadonlyFieldsMustBeginWithUpperCaseLetter
static
与
readonly
字段首字母大写
SA1312 VariableNamesMustBeginWithLowerCaseLetter 变量名必须是驼峰命名法
SA1313 ParameterNamesMustBeginWithLowerCaseLetter 参数名称必须是驼峰命名法
SA1314 TypeParameterNamesMustBeginWithT 类型变量必须以T开头
SX1309 FieldNamesMustBeginWithUnderscore 字段名称必须是下划线开头 这是netcore中官方建议的的编写
SX1309S StaticFieldNamesMustBeginWithUnderscore 静态字段名称必须是下划线开头 这是netcore中官方建议的的编写
SA1200 UsingDirectivesMustBePlacedWithinNamespace
using
部分必须在Namespace内部
SA1201 ElementsMustAppearInTheCorrectOrder 所有的元素必须出现在正确的位置上(个人不建议使用该规则,用region把一个类文件里的元素分好组即可,字段
SA1202 ElementsMustBeOrderedByAccess 元素的修饰符有一个固定的顺序(个人不建议使用该规则,用region把一个类文件里的元素分好组即可,字段
SA1203 ConstantsMustAppearBeforeFields 常量字段摆放在其它字段之上
SA1204 StaticElementsMustAppearBeforeInstanceElements Static 元素摆放在前面
SA1205 PartialElementsMustDeclareAccess Partial 修饰的元素必须声明读写权限
SA1206 DeclarationKeywordsMustFollowOrder 举例
SA1207 ProtectedMustComeBeforeInternal Protected在Internal之前
SA1208 SystemUsingDirectivesMustBePlacedBeforeOtherUsingDirectives 系统级的引用在其他引用之前(格式化代码就会自动按照这个规则编排
using
部分)
SA1209 UsingAliasDirectivesMustBePlacedAfterOtherUsingDirectives
using
部分起别名的在最后排布
SA1210 UsingDirectivesMustBeOrderedAlphabeticallyByNamespace
using
部分按照字母顺序编排
SA1211 UsingAliasDirectivesMustBeOrderedAlphabeticallyByAliasName 别名的按照别名的字母编排
SA1212 PropertyAccessorsMustFollowOrder 属性按照先
get
在
set
SA1213 EventAccessorsMustFollowOrder 时间先remove在add
SA1214 StaticReadonlyElementsMustAppearBeforeStaticNonReadonlyElements StaticReadonly元素在StaticNonReadonly元素之前
SA1216 UsingStaticDirectivesMustBePlacedAtTheCorrectLocation 静态指令按顺序放
SA1217 UsingStaticDirectivesMustBeOrderedAlphabetically 静态指令按顺序放
SA1100 DoNotPrefixCallsWithBaseUnlessLocalImplementationExists
SA1101 PrefixLocalCallsWithThis ‘
this
.’前缀不能省略
SA1106 CodeMustNotContainEmptyStatements 不允许有空白的声明
SA1107 CodeMustNotContainMultipleStatementsOnOneLine 同一行里不允许出现多个声明语句
SA1108 BlockStatementsMustNotContainEmbeddedComments 非法用例
SA1109 BlockStatementsMustNotContainEmbeddedRegions 非法用例
SA1110 OpeningParenthesisMustBeOnDeclarationLine 方法开始的括弧要在声明的那一行
SA1111 ClosingParenthesisMustBeOnLineOfLastParameter 方法结束括弧与最后一个参数同行
SA1112 ClosingParenthesisMustBeOnLineOfOpeningParenthesis 如果是空参的情况,开始于结束括弧在同一行
SA1113 CommaMustBeOnSameLineAsPreviousParameter 逗号必须与前一个参数同行
SA1114 ParameterListMustFollowDeclaration 确保参数列表与开始括号同行,或者另起一行 参数整体要在同一行
SA1115 ParameterMustFollowComma 参数与参数之间不能隔空白行
SA1116 SplitParametersMustStartOnLineAfterDeclaration 所有参数在同一行或者如下示例
SA1117 ParametersMustBeOnSameLineOrSeparateLines 同上
SA1118 ParameterMustNotSpanMultipleLines 实际调用是参数要在同一行
SA1120 CommentsMustContainText 注释必须节点内部必须有文本
SA1121 UseBuiltInTypeAlias 使用内嵌的类型别名
SA1122 UseStringEmptyForEmptyStrings 示例代码:“
string
s =
string
.Empty;”不能写成”
string
s =
""
; ”
SA1123 DoNotPlaceRegionsWithinElements 不使用region(个人较反对这条,个人倾向于用region规整类里的元素)
SA1124 DoNotUseRegions 不使用region(个人较反对这条,个人倾向于用region规整类里的元素)
SA1125 UseShorthandForNullableTypes 使用简写版的可空类型 如”
int
?”
SA1126 PrefixCallsCorrectly 调用类成员的时候要带上“
this
”前缀
SA1127 GenericTypeConstraintsMustBeOnOwnLine 泛型约束必须在同一行
SA1128 ConstructorInitializerMustBeOnOwnLine 同上
SA1129 DoNotUseDefaultValueTypeConstructor 不要使用默认值类型构造函数。
SA1130 UseLambdaSyntax 使用Lambda表达式
SA1131 UseReadableConditions 使用可读的条件
SA1132 DoNotCombineFields
SA1133 DoNotCombineAttributes
SA1134 AttributesMustNotShareLine
SA1136 EnumValuesShouldBeOnSeparateLines
SA1137 ElementsShouldHaveTheSameIndentation
SA1139 UseLiteralSuffixNotationInsteadOfCasting
SX1101 DoNotPrefixLocalMembersWithThis
SA1000 KeywordsMustBeSpacedCorrectly 关键字不能拼写错误
SA1001 CommasMustBeSpacedCorrectly 逗号前面摆放一个空格
SA1002 SemicolonsMustBeSpacedCorrectly 分号前面摆放一个空格
SA1003 SymbolsMustBeSpacedCorrectly 操作符与元素之间不加空格
SA1004 DocumentationLinesMustBeginWithSingleSpace “
///”注释的每一行以一个空格开头
SA1005 SingleLineCommentsMustBeginWithSingleSpace 单行注释以一个空格开头
SA1006 PreprocessorKeywordsMustNotBePrecededBySpace 预处理关键字内部不允许出现空格 如“#
if
Debug”是不允许的
SA1007 OperatorKeywordMustBeFollowedBySpace 操作必须要在一个空格之后
SA1008 OpeningParenthesisMustBeSpacedCorrectly 开始括弧放置合理的空格
SA1009 ClosingParenthesisMustBeSpacedCorrectly 结尾括弧放置合理的空格
SA1010 OpeningSquareBracketsMustBeSpacedCorrectly 开始方括号放置合理的空格
SA1011 ClosingSquareBracketsMustBeSpacedCorrectly 结束方括号放置合理的空格
SA1012 OpeningCurlyBracketsMustBeSpacedCorrectly 开始花括号放置合理的空格
SA1013 ClosingCurlyBracketsMustBeSpacedCorrectly 结束花括号放置合理的空格
SA1014 OpeningGenericBracketsMustBeSpacedCorrectly 同上
SA1015 ClosingGenericBracketsMustBeSpacedCorrectly 同上
SA1016 OpeningAttributeBracketsMustBeSpacedCorrectly 特性开始括号同上
SA1017 ClosingAttributeBracketsMustBeSpacedCorrectly 特性结尾括号同上
SA1018 NullableTypeSymbolsMustNotBePrecededBySpace 空类型前不放置空格
SA1019 MemberAccessSymbolsMustBeSpacedCorrectly 成员访问关键字前后有空格
SA1020 IncrementDecrementSymbolsMustBeSpacedCorrectly 自增自减关键字要有空格
SA1021 NegativeSignsMustBeSpacedCorrectly 负号要有空格
SA1022 PositiveSignsMustBeSpacedCorrectly 正号要有空格
SA1023 DereferenceAndAccessOfMustBeSpacedCorrectly
SA1024 ColonsMustBeSpacedCorrectly 冒号运算符要有空格
SA1025 CodeMustNotContainMultipleWhitespaceInARow 同一行不允许出现多个空格
SA1026 CodeMustNotContainSpaceAfterNewKeywordInImplicitlyTypedArrayAllocation
new
关键字之后不允许出现空格
SA1027 TabsMustNotBeUsed 不用tab字符
SA1028 CodeMustNotContainTrailingWhitespace 代码后面不能有空格
SA0001 XmlCommentAnalysisDisabled 禁用XML注释
SA0002 InvalidSettingsFile 无效的配置文件