C#开发手册
一、 编码规范
(一)【强制】命名规范:所有命名(类名、属性名、变量名、常量名、属性名)必须以字母开头(a-z、A-Z),不能以特殊字符(_、$)开头。
1、【强制】类名命名规则:大驼峰命名法【DTO、POCO、VO等除外】
public class UserInfo{}
2、【强制】属性命名规则:大驼峰命名法
public string UserInfo { get; set; }
3、【强制】字段、参数、成员变量、局部变量命名规则:小驼峰命名法
public string userName;
public string GetUserName(string userId) { return "userName"; }
4、【强制】方法/函数命名规则:大驼峰命名法
public int GetUserInfo() { }
5、【强制】常量命名规则:名称全部大写,单词间用下划线_分开
public const string USER_NAME = "userinfo";
6、【强制】DTO、POCO、VO命名规则:大驼峰命名法+DTO/VO/POCO等
public class UserInfoDTO { }
public class UserInfoVO { }
public class UserInfoPOCO { }
7、【强制】命名空间命名规则:大驼峰命名法
namespace UserInfo { }
8、【强制】枚举命名规则(枚举名称采用大驼峰命名规则,枚举成员所有名称也使用大驼峰命名法)(没有特殊情况的话,枚举成员建议从默认值0开始)
public enum UserState
{
Success,
Fail
}
9、【强制】代码中所有成员禁止直接使用中文的命名方式,禁止使用中文拼音命名(一些通用的命名除外:比如城市可以采用beiJing、shangHai这样的命名规则是可以的),禁止使用中英文混合命名方式,禁止出现a、b、c、aa、ss、x、xx等毫无意义的命名方式。
10、【推荐】复数类型(集合类、数组等)命名规则:优先以小写字符s结尾,如果单词最后的字母就是s或其他不适合s结尾的单词,可以使用复数类型的类型名称结尾(如List、Array等结尾)。前面规则如果都不好命名,可自行命名。
public List<string> userNames { get; set; }
public string[] userNameArray { get; set; }
public List<string> userNameList { get; set; }
11、【强制】接口命名规则:以大写字母I开头+类名称
public interface IUserInfo { }
12、【强制】异常类命名规则:大驼峰命名法+Exception
public class UserInfoException { }
13、【强制】项目命名规则:大驼峰命名法,各个字母之间用字母(.)隔开。
14、【推荐】业务层和数据层名命名规则:业务层类库名称命名规则:以Service结尾、数据层类库命名规则:以Repository结尾。
1)、获取数据的方法以Get开头(加上要获取的对象名)。如获取单个对象,可以使用Get()、GetUserInfo()。获取复数对象(集合类),可以使用Gets()、GetUserInfos()。
public class UserInfoService
{
/// <summary>
/// 获取一条用户信息【命名规则:直接用Get命名】
/// </summary>
/// <param name="userId">用户Id</param>
/// <returns></returns>
public UserInfo Get(string userId)
{
return null;
}
/// <summary>
/// 获取一条用户信息【命名规则:Get+对象名】
/// </summary>
/// <param name="userId">用户Id</param>
/// <returns></returns>
public UserInfo GetUserInfo(string userId)
{
return null;
}
/// <summary>
/// 获取多条用户信息【命名规则:Gets】
/// </summary>
/// <returns></returns>
public IEnumerable<UserInfo> Gets()
{
return null;
}
/// <summary>
/// 获取多条用户信息【命名规则:Get+对象名复数】
/// </summary>
/// <returns></returns>
public IEnumerable<UserInfo> GetUserInfos()
{
return null;
}
}
2)、新增数据的方法以Insert开头(加上要获取的对象名)。如往数据库中新增一条记录,方法命名为Insert()、InsertUserInfo()。往数据库中新增多条记录,方法命名为Inserts()、InsertUserInfos()。
public class UserInfoService
{/// <summary>
/// 新增一条用户信息【命名规则:Insert命名】
/// </summary>
/// <param name="userInfo">用户信息</param>
/// <returns></returns>
public int Insert(UserInfo userInfo)
{
return 1;
}
/// <summary>
/// 新增一条用户信息【命名规则:Insert+对象名】
/// </summary>
/// <param name="userInfo">用户信息</param>
/// <returns></returns>
public int InsertUserInfo(UserInfo userInfo)
{
return 1;
}
/// <summary>
/// 新增多条用户信息【命名规则:Inserts】
/// </summary>
/// <param name="userInfos">用户信息</param>
/// <returns></returns>
public int Inserts(List<UserInfo> userInfos)
{
return 1;
}
/// <summary>
/// 新增多条用户信息【命名规则:Insert+对象名复数】
/// </summary>
/// <param name="userInfos">用户信息</param>
/// <returns></returns>
public int InsertUserInfos(List<UserInfo> userInfos)
{
return 1;
}
}
3)、删除数据的方法以Delete/Remove(加上要删除的对象名)。如删除数据库中的一条记录,方法命名为Delete()、DeleteUserInfo()。删除数据库中的多条记录,方法命名为Deletes()、DeleteUserInfos()。
public class UserInfoService
{/// <summary>
/// 删除一条用户信息【命名规则:Delete】
/// </summary>
/// <param name="userId">用户Id</param>
/// <returns></returns>
public int Delete(string userId)
{
return 1;
}
/// <summary>
/// 删除一条用户信息【命名规则:Delete+对象名】
/// </summary>
/// <param name="userId">用户Id</param>
/// <returns></returns>
public int DeleteUserInfo(string userId)
{
return 1;
}
/// <summary>
/// 删除多条用户信息【命名规则:Deletes】
/// </summary>
/// <param name="userIds">要删除的用户Id集合</param>
/// <returns></returns>
public int Deletes(List<string> userIds)
{
return 1;
} /// <summary>
/// 删除多条用户信息【命名规则:Delete+对象名复数】
/// </summary>
/// <param name="userIds">要删除的用户Id集合</param>
/// <returns></returns>
public int DeleteUserInfos(List<string> userIds)
{
return 1;
}
}
4)、修改数据的方法以Update开头(加上要修改的对象名)。如修改一条数据信息,方法命名为Update()、UpdateUserInfo()。修改多条数据的信息,方法命名为Updates()、UpdateUserInfos()。
public class UserInfoService
{/// <summary>
/// 修改一条用户信息【命名规则:Update】
/// </summary>
/// <param name="userInfo">用户信息</param>
/// <returns></returns>
public int Update(UserInfo userInfo)
{
return 1;
}
/// <summary>
/// 修改一条用户信息【命名规则:Update+对象名】
/// </summary>
/// <param name="userInfo">用户信息</param>
/// <returns></returns>
public int UpdateUserInfo(UserInfo userInfo)
{
return 1;
}
/// <summary>
/// 修改一条用户信息【命名规则:Update】
/// </summary>
/// <param name="userInfo">用户信息</param>
/// <returns></returns>
public int Updates(UserInfo userInfo)
{
return 1;
}
/// <summary>
/// 修改一条用户信息【命名规则:Update+对象名】
/// </summary>
/// <param name="userInfo">用户信息</param>
/// <returns></returns>
public int UpdateUserInfos(UserInfo userInfo)
{
return 1;
}
}
C#开发手册的更多相关文章
- Net力软快速信息化系统开发框架 + 开发手册+数据库说明
源码目录结构说明LeaRun.Cache –缓存层LeaRun.Resource –本地语言LeaRun.Utilities –公共类库LeaRun.DataAccess –数据库访问核心组件LeaR ...
- 在线教学、视频会议 Webus Fox(2) 服务端开发手册
上次在<在线教学.视频会议软件 Webus Fox(1)文本.语音.视频聊天及电子白板基本用法>里介绍了软件的基本用法.本文主要介绍服务器端如何配置.开发. 1. 配置 1.1 IIS配置 ...
- 在线教学、视频会议 Webus Fox(3) 客户端开发手册
本文主要介绍webus fox 客户端的配置及接口说明. 1. 文件列表和配置 1.1 文件列表 1.2 common.xml 配置 根据服务器端的部署, 替换[ServerUrl] , [RtmpP ...
- Navi.Soft30.开放平台.聚合.开发手册
1系统简介 1.1功能简述 现在是一个信息时代,并且正在高速发展.以前获取信息的途径非常少,可能只有电视台,收音机等有限的来源,而现在的途径数不胜数,如:QQ,微信,官方网站,个人网站等等 本开发手册 ...
- Navi.Soft30.开放平台.腾讯.开发手册
1系统简介 1.1功能简述 现在是一个信息时代,并且正在高速发展.以前获取信息的途径非常少,可能只有电视台,收音机等有限的来源,而现在的途径数不胜数,如:QQ,微信,官方网站,个人网站等等 本开发手册 ...
- Navi.Soft30.开放平台.百度.开发手册
1系统简介 1.1功能简述 现在是一个信息时代,并且正在高速发展.以前获取信息的途径非常少,可能只有电视台,收音机等有限的来源,而现在的途径数不胜数,如:QQ,微信,官方网站,个人网站等等 本开发手册 ...
- Navi.Soft30.框架.WinForm.开发手册
阅读导航 Navi.Soft30.Core类库.开发手册 http://www.cnblogs.com/xiyang1011/p/5709489.html Navi.Soft30.框架.WinForm ...
- Discuz!开发手册
如何使用Discuz开发手册? 1.首先建议你了解Discuz目录结构-全局篇 通过对目录结构的了解,会在以后的创作道路上提供坚实的基础! 2.你还需要了解Discuz! X3.1数据字典 3.创建自 ...
- dzzoffice教程、文档、开发手册等内容地址
dzzoffice教程.文档.开发手册等内容全部都存放在DzzOffice开发者社区的文集中.搜索引擎收录不到DzzOffice中的应用内容,这里将文集地址提供在这里. 地址:http://dev.d ...
- Java开发手册
<Java开发手册> 基本信息 作者: 桂颖 谷涛 出版社:电子工业出版社 ISBN:9787121209161 上架时间:2013-8-12 出版日期:2013 年7月 开本 ...
随机推荐
- 【Python】【Jupyter】Jupyter 的简单使用 与 Python的基本输出输入
上课无聊写着玩的,不必当真. Jupyter 的简单使用 与 Python的基本输出输入 目录 Jupyter 的简单使用 与 Python的基本输出输入 数据准备 输出 输入 一些练习 print( ...
- .NET 阻止系统睡眠/息屏
本文介绍Windows系统设备下如何阻止系统睡眠/息屏,以及想看当前阻止睡眠/息屏的应用信息 powercfg /requests查看活动列表 在播放音乐时,我们会发现设置了系统电源管理-自动睡眠,计 ...
- APP网站小程序微信登录同步:需要微信公众号、小程序、开放平台打通用户体系(不同主体也行)
要想APP网站小程序微信登录同步打通用户体系.我们需要将(不同主体也行)多个公众号和小程序都绑定到同一个微信开放平台上,获取到UnionID记录到数据库就可以了. 微信UnionID 机制说明 如果开 ...
- Java多线程处理文件详解与代码示例
在Java编程中,文件处理是一项常见的任务.当需要处理大量文件或处理文件的时间较长时,单线程的处理方式可能会显得效率低下.为了提高文件处理的效率,我们可以使用多线程技术.本文将详细介绍如何使用Java ...
- dectron2框架export导出并使用 onnx 记录
python tools/deploy/export_model.py \ --sample-image /Users/gatilin/PycharmProjects/model-graphviz-p ...
- SHAPEIT算法简介
本文是基于SHAPIT2和SHAPEIT4的,先介绍SHAPEIT2的算法原理,然后简单介绍了一下SHAPEIT4更新的部分.文中介绍主要集中在算法部分,比较简介,具体内容请看参考文献. [SHAPE ...
- Solution -「GLR-R4」芒种
\(\mathscr{Description}\) Link, 懒得概括题意.jpg \(\mathscr{Solution}\) Subtask 1 \((n,m\le2)\) 一共只有五种 ...
- NET Core3.1 Cors 添加跨域支持
在 Startup 里加: services.AddCors(options => options.AddPolicy( DefaultCors, p => p.SetIsOriginAl ...
- MySQL 开发规范
建表规约 1.[强制]每张表必须设置一个主键ID,并且这个主键ID要自增(在满足需要的情况下尽量短),除非是分库分表 理解:由于InnoDB存储引擎决定了需要有一个主键,而且这个主键ID是自增的话可以 ...
- web应用分页-copy
1. 场景描述 目前大部分的应用程序中都会用到分页功能,以便减少前端浏览器及后台服务器的压力,以及其他方面的考虑. (1)分页从概念上可分为逻辑分页和物理分页,逻辑分页主要是通过应用程序(前端或者后端 ...