点注《C# Coding Standard》Charpter One

standard

1 命名规则与风格
在以前版本的Visual Studio中,微软曾建议使用匈牙利命名法来写代码.在最近发布的.NET和它的编程语言中,微软更换了他的这一法则.

1. 对格式与方法名称使用PASCAL风格[1]

public class SomeClass

{

public SomeMethod(){}

}

2. 对局部变量和方法参数使用Camel风格[2]

int number;

void MyMethod(int someNumber)

{}

3. 使用I作为接口前缀

interface IMyInterface

{..}

4. 使用m_作为私有成员变量前缀

public class SomeClass

{

private int m_Number;

}

5. 使用Attribute作为自定义属性类的后缀

6. 使用Exception作为自定义异常处理类的后缀

7. 使用动词形式命名方法名,如ShowDialog()

8. 带有返回值的方法应该有一个方法来描述返回值,如GetObjectStatus()

9. 使用易描述的变量名称

l 避免使用单一字符描述变量名称,如i或t.应使用index或temp替代

l 对共有以及受保护成员避免使用匈牙利命名法则[3]

l 绝不使用缩写字符,如使用num代替number

10. 总是使用C#预定义格式,而不使用在System空间内的别名

object NOT 0bject

string NOT String

int NOT Int32

11. 一般的,对于格式使用大写字母,当处理.NET格式Type时使用Type后缀

//Correct:

public class LinkedList<K, T>

{..}

//Avoid:

public class LinkedList<KeyType,DataType>

{..}

12. 使用易理解的命名空间[4]名称,如产品或公司名称

13. 避免使用命名空间的完整限定名称,应使用using声明替代

14. 避免using声明放置在命名空间内部

15. 将所有的框架命名空间分组,将用户或第三方命名空间放置在其下

using System;

using System.Collections;

using System.ComponentModel;

using System.Data;

using MyCompany;

using MyControls;

16. 使用委托引用[5]代替显式的委托实例

delegate void SomeDelegate();

public void SomeMethod()

{..}

SomeDelegate someDelegate=SomeMethod;

17. 保持严格的缩进

l 对缩进使用3个空格位

l 绝不使用TAB或者不标准的缩进,如1,2或4个空格位

18. 将注释缩拍在与代码缩进同等级的位置上

19. 所有的注释应该通过拼写检查.拼错的注释将预示冗余的开发

20. 所有的成员变量应该在开始就被声明,并使用单独一行将属性与方法区域分开

public class MyClass

{

int m_Number;

string m_Name;

public void SomeMethodl()

{}

public void SomeMethod2()

{}

}

21. 在离第一次使用变量尽可能近的地方声明该局部变量

22. 文件名称应反映出其包含的类

23. 当使用partial类[6]并将其分配给每个文件一部分时,对每个文件命名使用后缀P并附带一个额外的数字

//In MyClassP1.cs

public partial class MyClass

{..}

// In MyClassP2.cs

public partial class MyClass

{..}

24. 将反括号({)放置与新的一行

25. 对于匿名方法参照有规律的代码规划,其缩进应与匿名委托声明对齐

delegate void SomeDelegate (string someString);

//Correct:

public void InvokeMethod()

{

SomeDelegate someDelegate=delegate (string name)

{

MessageBox.Show(name);

};

someDelegate ("Juval");

}

//Avoid

public void InvokeMethod()

{

SomeDelegate someDelegate=delegate (string name)

{MessageBox.Show(name);};

someDelegate(”Juval");

}

26. 对于匿名缺省参数的方法,应该使用空括号表示.

delegate void SomeDelegate();

//Correct

SomeDelegate someDelegate1=delegate()

{

MessageBox.Show("Hello");

};

//Avoid

SomeDelegate someDelegate1=delegate

{

MessageBox.Show("Hello");

};

由于本人E文有限,所以翻译注释不当之处,请指明。

稍后是第二部分——编码实践,不过要点时间了,因为会有较多注释(我的习惯啦)

--------------------------------------------------------------------------------

[1] 特指使用Pascal的命名规范命名类型和方法的名字

[2] 特指使用camel命名规范命名局部变量和方法的参数

[3] 匈牙利命名法则:变量名=变量类型+变量的英文意思(或缩写)

[4] namespace用于声明一个范围.此命名空间范围允许您组织代码并为您提供了创建全局唯一类型的方法.

[5] delegate声明定义一种引用类型,该类型可用于将方法用特定的签名封装.委托实例封装静态方法或实例方法. 委托大致类似于C++中的函数指针;但是,委托是类型安全和可靠的

[6] partial简单来说即是使用不完整的类定义并且将部分分配到每个文件中

时间: 2024-11-02 05:35:00

点注《C# Coding Standard》Charpter One的相关文章

PHP编码规范-php coding standard

standard|编码|规范 目录 介绍 标准化的重要性 解释 认同观点 项目的四个阶段 命名规则 合适的命名 缩写词不要全部使用大写字母 类命名 类库命名 方法命名 类属性命名 方法中参数命名 变量命名 引用变量和函数返回引用 全局变量 定义命名 / 全局常量 静态变量 函数命名 php文件扩展名 文档规则 评价注释 Comments Should Tell a Story Document Decisions 使用标头说明 Make Gotchas Explicit Interface an

WCF服务编程设计规范(1):最新版WCF Coding Standard介绍

<WCF4.0新特性体验>之后,新出一个系列<WCF服务编程设计规范>.这个系列主要关注的是如何设计WCF服务,以及WCF编码规范.这里我会翻译整理一些WCF服务设计相关的资料,分享给大家,并提供英文原版的下载. [1]序言: 这个系列应该实用性比较强,对于大多数使用到WCF的技术人员或者公司来说,都是比较重要的内容,我们需要一套完整的规范来指导服务的设计和编码.这可以作为大家学习WCF一个规范参考,另外如果公司制定WCF相关的编码和服务设计规范的时候,可以参考一下.我会在这个系列

C# Coding Standard

standard 在以前版本的Visual Studio中,微软曾建议使用匈牙利命名法来写代码.在最近发布的.NET和它的编程语言中,微软更换了他的这一法则. 1. 对格式与方法名称使用PASCAL风格[1] public class SomeClass { public SomeMethod(){} } 2. 对局部变量和方法参数使用Camel风格[2] int number; void MyMethod(int someNumber) {} 3. 使用I作为接口前缀 interface IM

Good Java Style: Part 2

Good Java Style: Part 2By Thornton Rose IntroductionThis is the conclusion of a two-part series on Java coding style. In Good Java Style: Part 1 , I introduced my case for writing Java code using good habits, explained why we should care about the wa

Good Java Style: Part 1

Good Java Style: Part 1By Thornton Rose IntroductionHaving worked as a software developer and consultant for many years, I have seen a large amount of code in a variety of programming languages. It has run the gamut from elegant to ugly, and unfortun

IDesign C#编程规范(二)

编程|规范 续之一,小鸡射手接着翻译了IDesign编码规范的第二章前部. 2 编码惯例 Coding Practices 1. 避免在一个文件中放多个类. Avoid putting multiple classes in a single file. 2. 一个文件应该只对一个命名空间提供类型.避免在同一文件中有多个命名空间. A single file should only contribute types to a single namespace. Avoid having mult

C#命名规则和开发习惯

C# Coding Standard 一.命名 1.用pascal规则来命名方法和类型. public class TextBox { public void DataBind() { } } 2.用camel规则来命名局部变量和方法的参数. string userName; public AddUser(string userId, byte[] password); 3.所有的成员变量前加前缀 m_ public class Database { public string m_connec

Composer使用

是什么 如果你知道yum.apt-get.npm.bower等命令中的一种或者多种,那么,你也能很快知道composer是什么了.没错,它就是PHP里快速安装类库的.平时,我们安装一个PHP类库,需要搜索->下载:使用composer,我们只要知道包名,直接composer insatll就可以了. PHP 语言本身就带有强大的网络功能.文件管理功能和丰富的系统 API,Composer 也只是一段 PHP 脚本而已. 引自Composer中文网的描述: 是 PHP 用来管理依赖(depende

Qt资料大全

简述 发福利了.发福利了.发福利了,重要的事情说三遍... 为了方便更多Qter了解.学习Qt,现将相关资源进行整理,主要内容包括:Qt官网.编码风格.GitHub & Third-Party.社区论坛.博客.书籍等. 满满的都是干货,独乐乐不如众乐乐... 简述 Qt官网 编码风格 GitHub Third-Party 社区论坛 博客 书籍 更多 Qt官网 Qt官网:https://www.qt.io Qt下载:http://www.qt.io/download Qt所有下载:http://d