C#代码规范(湖南大学).doc

上传人:小** 文档编号:128300568 上传时间:2020-04-20 格式:DOC 页数:10 大小:97KB
返回 下载 相关 举报
C#代码规范(湖南大学).doc_第1页
第1页 / 共10页
C#代码规范(湖南大学).doc_第2页
第2页 / 共10页
C#代码规范(湖南大学).doc_第3页
第3页 / 共10页
C#代码规范(湖南大学).doc_第4页
第4页 / 共10页
C#代码规范(湖南大学).doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《C#代码规范(湖南大学).doc》由会员分享,可在线阅读,更多相关《C#代码规范(湖南大学).doc(10页珍藏版)》请在金锄头文库上搜索。

1、创新课程参考案例铁路局计量管理系统C#代码规范湖南大学软件学院2007年8月文档信息:文档编号MMIS-03文档名称计量系统C#代码规范文档描述该文档详细定义了计量系统开发中的C#代码编写规范,本文档是后续分模块程序编码的规范性文档。VSS中文档存放路径$/学院/软件开发部/计量系统/开发设计文档负责人状态定稿文档变更记录:时间修改人章节描述2007-05-29陈浩所有创建新文档相关文档:文档路径计量系统需求分析说明书$/学院/软件开发部/计量系统/开发设计文档计量系统功能说明书$/学院/软件开发部/计量系统/开发设计文档文档确认与评审记录:审核人审核时间意见备注项目组2005-7-28评审通

2、过用户评审确认目 录1编程风格41.1统一编程风格的意义41.2变量命名规则41.3函数命名规则51.4类命名规则51.5常见语句书写规则61.6注释风格72代码组织73代码优化83.1代码优化的意义83.2函数内的代码优化83.3类内的代码优化93.4类之间的代码优化104调试技巧104.1编译时的错误104.2运行时的错误104.3C#常见问题111 编程风格1.1 统一编程风格的意义 增加开发过程代码的强壮性、可读性、易维护性 减少有经验和无经验开发人员编程所需的脑力工作 为软件的良好维护性打下好的基础 在项目范围内统一代码风格 通过人为以及自动的方式对最终软件应用质量标准 使新的开发人

3、员快速适应项目氛围 支持项目资源的复用:允许开发人员从一个项目区域(或子项目团队)移动到另一个,而不需要重新适应新的子项目团队的氛围 一个优秀而且职业化的开发团队所必需的素质1.2 变量命名规则 前缀(小写字母加下划线)表明变量的作用域,无前缀则表明是局部变量或函数的参数。如: m_xx表示是类的成员变量,控件变量例外 g_xx表示是全局变量,在C#中,也可以理解为在整个项目中都可能用到的静态变量 c_xx或者XX表示是一个常量 用数据类型全称中的关键字母代表特定的数据类型(一个或多个小写字母),如下表。常用数据类型缩写数据类型iintbboolstrstringccharffloatddou

4、bleobobjectlblLabeltxtTextBoxbtnButtoncmbComboBoxmnuMainmenumnuItemMenuItemchkCheckBoxgrdDataGridtmTimerfrmFormpnlPanelgupGroupBoxtvTreeViewrdoRadioButtonlbListBoxtlbToolBardtDateTimecnConnectioncmdCommanddsDataSetdaDataAdapterdvDataViewdbTableDataTabledbReaderDataReaderparamParameterdbRowDataRowdbC

5、olDataColumn注:如果模块中只有一个类实例对象,则可以只用简写。如Connection对象可以用cn来命名。1.3 函数命名规则 函数名用首字母大写的英文单词组合表示(如用动词+名词的方法),其中至少有一个动词 应该避免的命名方式 和继承来的函数名一样。即使函数的参数不一样,也尽量不要这么做,除非想要重载它 只由一个动词组成,如:Save、Update。改成如:SaveValue、UpdateDataSet则比较好 函数参数的命名规则 函数参数应该具有自我描述性,应该能够做到见其名而知其意 用匈牙利命名法命名1.4 类命名规则 类的命名通常以父类的简写开头。如:FrmXXX可看出该类

6、从Form中继承而来 类名中尽量不要出现下划线 类变量的命名可以参照,如:FrmXXX frmXXX = new FrmXXX(),即首字母小写即可1.5 常见语句书写规则如下表所示。语句提倡的风格ifif(condition)statements;elsestatements;forfor(initialization; condition; update)statements;foreachforeach(something in collection)statements;switchswitch()case .:break;case :break;default:whilewhile(

7、.)statements;do-whiledostatements;while(condition);try-catchtrystatements;catch(Exception e)handle exception;同一代码块内的不同逻辑块之间应空一行do statement1;do statement2;函数与函数之间至少空一行,但不超三行1.6 注释风格 注释应该正确、简洁、有重点 应该写优雅的、可读性良好的代码,而不是为玄妙、晦涩的代码写注释 原则上应尽量减少程序体内代码的注释,应该保持代码本身的直接可读性 函数的注释,可以只对public或者重要的private函数进行注解2 代码组

8、织代码组织是对整个项目的代码进行整理,使之更加有序。实现类似功能的文件应该放在同一个文件夹中或者同一个项目中。例如,可把整个项目分为以下几个层次: SystemFramework层提供一些给其他公用的服务,比如说系统日志、应用程序配置、异常处理、调试类等读取Web.config和*.exe.config一般都在这一层。 Common层把逻辑上的tables抽象成一些类,这些类一般从DataSet继承,生成一些strong typed Dataset,类中不涉及任何数据库操作。 DataAccess层这一层的类负责与数据库的连接,以Common层对象为媒介读取、更新、添加、删除数据库对象。为Bu

9、ssiness层提供数据服务。 Bussiness Logic 层如果需要的话可以分为以下两层,也可以合为一层。 Business Rule层包含各种商务逻辑和规则。 Business Faade层提供给UI层所有的系统接口,这一层抽象出了UI层所需要用到的功能。这一层的类可以通过继承MarshalByRefObject类,支持Remoting,配置到专门的应用程序服务器上。 UI层只调用Bussiness层和SystemFramework层的接口,实现用户界面。包括: WinUI WebUI WebService(并不是用户界面,但是逻辑上属于这一层)3 代码优化3.1 代码优化的意义 仅仅

10、对符合功能说明书的要求、能正确运行的代码进行优化是有意义的 代码优化能减少冗余代码的数量,用更少的代码来实现同样的功能 提高代码的内聚程度,减少耦合程度 对代码的抽象能提高代码的重用度,对今后其他项目的进度有非常重要的意义3.2 函数内的代码优化 去掉从来没有用到过的参数 始终进行参数检验。不要认为只有我才会调用这个函数,我能够保证参数的有效性。事实上很多运行错误就是没有对参数进行检验。对于传入了非法值的函数调用,可以返回一个对调用无意义的值(如:null,-1),或者干脆抛出一个异常 函数的参数不宜过多,如果实在是太多,可以考虑将这些参数封装在一个类中,然后将这个类的某个实例作为参数传入函数

11、 如果函数从来不会修改某个参数的值,则应该尽量将参数声明为const 如果函数中用到的类成员变量或者其他全局变量可以用传入参数的方式代替,则用参数代替,这样可以减少该函数和外界的关系,提高内聚 一个单一的函数的代码量不宜过多。如果实在很多,则可以把它切分成小的函数,例如长的switch语句是最容易切分的 单个函数中尽量避免相同的代码,可以用条件语句或者抽取出来作为函数的方法消除这些冗余 尽量保持函数只有一个出口,即只有一处return语句,如: 原始代码string GetControlText(int nIndex)if(ParameterValid() = false)return nul

12、l;switch(nIndex)case 0:return txtValue1.Text;case 1:return txtValue2.Text;. 优化过的代码string GetControlText(int nIndex)string strReturnValue = null;if(ParameterValid() = true)switch(nIndex)case 0:strReturnValue = txtValue1.Text;break;case 1:strReturnValue = txtValue2.Text;break;.return strReturnValue;3.

13、3 类内的代码优化 只有类对外的接口才声明为public 在类的成员函数中如果存在着相同的代码,则将其抽取成为private的成员函数,以减少代码的冗余,保持在一个类中没有相同的两份代码的副本 尽量减少成员函数之间的依赖,特别是对成员变量值的依赖3.4 类之间的代码优化 类应该是一个实体,具有自己的数据和对这些数据的操作 把界面操作和数据处理分离在两个类中是比较好的做法 对于不同类之间有相同代码的情况,有以下几种处理方法: 将相同的代码抽象出来作为父类,其他的类从中继承,由此来共享代码 将相同的代码抽象出来作为一个新类,其他类中声明一个该类的变量,由此来共享代码这两种方法各有利弊,前种方法比较适于当共享代码在调用之前必须做特殊的初始化,而这些初始化可能很难用函数调用来完成,这时父类的初始化代码中可以加入一个虚拟函数,所有的子类都重载该函数,做特定的初始化;后种方法可以封装得很彻底,只暴露出对外的接口,和其

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 规章制度

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号