分享
 
 
 

点注《C# Coding Standard》Charpter One

王朝c#·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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简单来说即是使用不完整的类定义并且将部分分配到每个文件中

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有