一、程序集和动态链接库(DLL)的命名
程序集是一个部署单元,一般来说一个程序集仅与一个DLL对应。命名空间和DLL和程序集不是一个概念,命名空间一般来说是一个逻辑实体而DLL和程序集是用于打包和部署的一个单元,一个DLL可以包含多个命名空间,一般将DLL命名为System.Net 不一定命名空间也为System.Net。
首先、要为程序集或者DLL选择具有代表性的名字命名,比如:System.Net,一眼就能看出它的大致用途。这样的命名才是最合适的,才具有实际的意义。如果我们的命名不能很好的表达它具体的功能那么就需要重新考虑更改命名了,因为不能很好表达出具体功能的命名我认为就是失败的不合适的,因为这样的命名并没有给你带来任何好处反而让程序变得很混乱不之所云。
其次、推荐一种命名结构,即使用“公司名称/机构名称”+“.”+“组件名称”+”.”+”dll”的方式来命名。因为这样会使结构更清晰。
二、命名空间的命名
首先、命名空间要采用PascalCasing大小写风格,各部分用“.”隔开。
其次、要尽量使用“公司名称”为前缀,然后加组件描述名称,因为这样不会与其他第三方命名相冲突。
三、接口的命名
接口在实际工作中是我们经常接触到的,它是一种约束一种抽象,对于它的命名一般采用微软的命名习惯即:“I”+具体功能的描述。这种命名已经被大多数开发人员接受,一看见以大写I开头一般都会认为是接口。需要注意的是I后面的命名采用PascalCasing大小写风格并采用形容词有时也可以是名词来命名,如:ICollection。
四、类和结构的命名
类和结构一般采用PascalCasing大小写风格,采用名词或名词短语来命名。
不要为类名加前缀,比如“C”。
考虑在派生类结尾采用基类名称。
五、枚举类型的命名
这个也是目前我们公司争议最大的地方,有些人认为加“Enum”前缀或者后缀会更好一些,这样一眼就能确定它是枚举类型,还有一部分人认为应该墨守微软的陈规不应该加”Enum”的前缀或者后缀。公所公有理,婆说婆有理,最终我们目前采用的是“Enum”前缀命名方式。(少数服从多数吧)
枚举采用PascalCasing大小写风格。
六、方法的命名
采用PascalCasing大小写风格。
采用动词或者动词短语来命名方法。
七、属性的命名
采用PascalCasing大小写风格。
采用名称或者形容词来命名属性。
要采用项目短语的复数形式来命名集合属性。
要有肯定性的短语来命名布尔属性如:CanRead。
八、事件的命名
要采用PascalCasing大小写风格。
要采用动词或者动词短语的时态来表示事件发生时间。
要在处理函数加“EventHandler”后缀。
要在事件处理函数中采用“sender”“e”作为两个参数的名字。
要在命名时间参数时加“EventArgs”后缀。
九、字段的命名
采用Pasca大小写风格。
用名词、名称短语或者形容词来命名字段。
不要为字段加前缀。
十、参数的命名
采用camelCasing大小写风格。
要使用具有描述性的参数名称。