zoukankan      html  css  js  c++  java
  • 建立标准编码规则(四)-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	无效的配置文件
    

      

    禁止转载
  • 相关阅读:
    BZOJ 2653 middle
    BZOJ 3207 花神的嘲讽计划Ⅰ
    BZOJ 3689 异或之
    BZOJ 3037 创世纪
    BZOJ [1264] [ AHOI2006]基因匹配Match
    BZOJ 2186 [Sdoi2008]沙拉公主的困惑
    BZOJ 3362 Navigation Nightmare
    BZOJ 3209 花神的数论题
    BZOJ 1411 ZJOI2009 硬币游戏
    【HDU1573】X问题
  • 原文地址:https://www.cnblogs.com/fishpro/p/7881143.html
Copyright © 2011-2022 走看看