【C#编程最佳实践 七】代码书写规范实践

本文档提供了软件开发中的编码规范,包括布局、命名、注释等,旨在提高代码的可读性和可维护性。

以下规范都是个人书写习惯,便于阅读总结的个人规范,对于每个人可以有自己的理解。终极目标就是消除警告呀哈哈。

布局规范

对于项目的总体规范,建议分为以下几部分:1,对外提供服务的文件。2,配置文件和配置文件解析类(如果有)。3,接口文件夹(接口和实现类)。4单元测试文件夹。5,实体类文件夹。

命名规范

1,接口的命名:例如IConditionKeyBuilder,以I开头,方式+名词
2,类的命名:驼峰命名法
3,方法的命名:动词:GetConditionKey()
4,字段的命名:_keyCondition
5,属性的命名:GetConditionKey(在C#里能用属性不用字段,基本都用属性)

注释规范

类的注释

这里写图片描述

类+属性(服务提供类)或来源(某接口的实现类)+具体功能

接口的注释

这里写图片描述

接口+属性(字段比较规则接口)或来源(某接口的子接口)+具体功能

方法的注释

这里写图片描述

方法属性(私有还是公有)+功能+参数列表

属性的注释

这里写图片描述

属性要完成的功能

流程注释

这里写图片描述

1,数据预处理注释:这一部分用来预处理想要处理的数据
2,核心功能方法注释:核心功能为一个区域,用注释隔离开
3,辅助方法注释:辅助需要的方法为一个区域,也用注释隔离

每一个功能的辅助方法集合都要用一个region来包含,核心方法也是,用region隔开

常用规范

以下内容引自武哥,尊重知识产权https://www.evernote.com/shard/s69/sh/aabd8e65-b619-4a77-baf7-fde4886299b5/6ce578ef4547559d

1.能使用foreach 不使用 for

原因:
foreach (var i in getlist() )            //getlist() 只会执行一次
for(int i=0;i< getlist().count ;i++)     //getlist() 会执行多次

2.如果throw 的异常是一种己知的异常,应该自定义一个异常类

throw new Exception(“数据己存在”)
//改成  throw new DataExistedException()

3.有效复用

大代码中出现大量常见重复的判断值有效性或提取对象里的信息的场景,应该封装成一个函数方便复用。
示例:

if(obj.name==null || obj.list==null || obj.list.count==0)     
//添加函数 isValidValue(obj)
return $("{obj.app}.{obj.metaobject}.{obj.feildname}”)
//添加函数 obj.GetXX()   或  GetXX(obj)
return result=resultData.Count > 0 :true?false ;
//改成   isSuccess(resultData)

4.代码中常用或多个地方会使用到的字符串不能使用明文, 应该用常量。

示例
sortFields.Add("_uid", SortDirection.Asc);
//改成
public const string UID_Field = “_uid”
sortFields.Add(UID_Field, SortDirection.Asc);

5.参数有效性验证

代码给外层提供服务的接口,函数第一行, 就应该要给传入的参数进行有效性验证 (如:Provider中的public函数)

public DataResult<bool> ImportObjectData(string ids, bool isTransferAll = false)
{
   string[] idArray = ids.Split(',');
   if (ids.Count() > 0)
   {
       //run ….
   }
}

改成
public DataResult<bool> ImportObjectData(string ids, bool isTransferAll = false)
{
   ArgumentHelper.AssertPositive(ids, "ids");
   string[] idArray = ids.Split(',');
   if (ids.Count() > 0)
   {
       //run ….
   }
}

6.关于注释

  • 1.Model里的属性一定要有注释,同时要确保注释是正确的。

  • 2.Class一定要有描述是干什么事情的

  • 3.核心代码,关键算法一定要注释清楚为什么是这样做的,场景是什么?而不是只注释函数在干什么?

  • 4.函数的参数注释要与代码匹配

7.关于代码的可读性

1.每个函数一般要求“圈复杂度”不超过5

8.关于函数命名

1.函数命名要统一规范, 如: getXXX() getXXXs() isXXX() hasXXX()
2.函数命名要能表达函数的操作行为,命名应该是动词。 如: run() getXXX()

9.关于变量的使用

1.当变量只有一个地方使用时,就不使用变量。

示例:
Exception ex = new Exception("RelationFilter Range条件配置错误:" + User.Common.Serialize.SerializeHelper.Serialize(relationFilter));
throw ex;
改成
throw new Exception("RelationFilter Range条件配置错误:" + User.Common.Serialize.SerializeHelper.Serialize(relationFilter));

2.进行大量反复修改变量值时(如 i++ ),应该使用局部变量,不要直接使用全局变量进行i++操作. 这样性能更高。

示例
public static int i =0;
public void fun(){
    for(int n=0;n<1000;n++)
   {
        i++;
   }
}
改成
public void fun(){
   int i=0;
   for(int n=0;n<1000;n++)
   {
        i++;
   }
}

10.关判断参数是否为空

ArgumentHelper.AssertNotEmpty(name,”name”)
判断值是否大于0
ArgumentHelper.AssertPositive(userId,”userId”)
判断是否为null
ArgumentHelper.AssertNotNull(objectData,”objectData”)11.关于性能

1.使用String.Empty 代替 “"

string name="";
改成
string name=String.Empty;
C# 代码编写规范 目录 目录1目的..............................................................................................................................................2 1目的.......................................................................................................................................................4 2适应范围...............................................................................................................................................4 3术语及缩略语.......................................................................................................................................4 4规范内容...............................................................................................................................................4 4.1命名总体规则................................................................................................................................4 4.2命名规范........................................................................................................................................5 4.2.1变量命名.................................................................................................................................5 4.2.2常量命名.................................................................................................................................7 4.2.3类(Class)命名.........................................................................................................................7 4.2.4接口(Interface)命名................................................................................................................7 4.2.5方法(Method)命名..................................................................................................................8 4.2.6命名空间(NameSpace)命名...................................................................................................8 4.2.7属性(Property)命名................................................................................................................8 4.3注释规范........................................................................................................................................8 4.3.1概述.........................................................................................................................................8 4.3.2自建代码文件注释.................................................................................................................9 4.3.3模块(类)注释..........................................................................................................................9 4.3.4类属性注释...........................................................................................................................10 4.3.5方法注释...............................................................................................................................10 4.3.6代码间注释........................................................................................................................... 11 4.4编码规则...................................................................................................................................... 11 4.4.1错误检查规则....................................................................................................................... 11 4.4.2大括号规则........................................................................................................................... 11 4.4.3小括号规则........................................................................................................................... 11 4.4.4缩进规则...............................................................................................................................12 4.4.5对齐规则...............................................................................................................................12 4.4.6比较规则...............................................................................................................................12 4.4.7 Case规则..............................................................................................................................12 4.4.8 If … Else规则.......................................................................................................................12 4.4.9单语句规则...........................................................................................................................13 4.4.10单一功能准则.....................................................................................................................13 4.4.11简单功能准则.....................................................................................................................13 4.4.12明确条件规则.....................................................................................................................13 4.4.13选用False规则..................................................................................................................13 4.4.14独立赋值规则.....................................................................................................................13 4.4.15定义常量规则.....................................................................................................................14 4.4.16模块化规则.........................................................................................................................14 4.4.17交流规则.............................................................................................................................14 4.5编程准则......................................................................................................................................14 4.5.1变量使用...............................................................................................................................14 4.5.2数据库操作...........................................................................................................................14 4.5.3对象使用...............................................................................................................................15 4.5.4模块设计原则.......................................................................................................................15 4.5.5结构化要求...........................................................................................................................15 4.5.6函数返回值原则...................................................................................................................16 4.6代码规范..................................................................................................................................16 4.6.1代码包的版本号...................................................................................................................16 4.6.2代码包的标识.......................................................................................................................16 4.7代码控制......................................................................................................................................17 4.7.1代码库/目录的建立..............................................................................................................17 4.7.2代码归档...............................................................................................................................17 附件1:数据类型缩写表.................................................................................................................17 附件2:控件名缩写表.....................................................................................................................18 a、.NET控件................................................................................................................................18 b、html控件..................................................................................................................................19
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

存在morning

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值