java编程规范_第1页
java编程规范_第2页
java编程规范_第3页
java编程规范_第4页
java编程规范_第5页
已阅读5页,还剩36页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、java编程规范2013年11月6日目目 录录1.java命名规范2.书写格式规范3.代码文件风格1 JAVA命名规范命名规范为确保系统源程序可读性,从而增强系统可维护性,制定下述编程规范,以规范系统各部分编程。系统继承的其它资源中的源程序也应按此规范作相应修改。1.1公共约定公共约定 命名指系统中对源文件名、方法、目录、包、数据库表名、数据库字段等的命名。 系统所用的命名都使用英文缩写来表达。 命名的组成方式为:前缀+命名词素缩写,前缀表达出命名的用途,如数据库表等。 命名的前缀由项目组确定。 除系统公共维护对象外的其他对象,命名全部用小写。一种方式用“_”作连接符,另一种方式是词素的第一个

2、字母大写直接连接在一起。在本规范中,数据库名、数据库字段名采用第一种方式,其余采用第二种方式。 使用可以准确说明变量/字段/类/接口/包等的完整的英文描述符。例如,采用类似 firstName,listAllUsers 或 CorporateCustomer 这样的名字,严禁使用汉语拼音及不相关单词命名,虽然Java支持Unicode命名,但本规范规定对包、类、接口、方法、变量、字段等不得使用汉字等进行命名 采用大小写混合,提高名字的可读性。一般应该采用小写字母,但是类和接口的名字的首字母,以及任何中间单词的首字母应该大写。包名全部小写。 尽量少用缩写,但如果一定要使用,当使用公共缩写和习惯缩

3、写等,如实现(implement)可缩写成impl,经理(manager)可缩写成mgr等,严禁滥用缩写。 避免使用长名字(最好不超过 25 个字母)。 避免使用数字,但可用2代替to,用4代替for等,如:go2Jsp。 1.2Java文件、包文件、包 文件名当与其类严格相同,所有单词首字母大写。 包名一般以项目或模块名命名,少用缩写和长名,一律小写。 基本包:com.czpost,所有包、文件都从属于此包。 包名按如下规则组成: 基本包.项目名.模块名.子模块名. 如: com.czpost.eims com.hepost.eims.until 不得将类直接定义在基本包下,所有项目中的类、

4、接口等都当定义在各自的项目和模块包中。1.3类、接口命名规范类、接口命名规范 所有单词首字母大写。使用能确切反应该类、接口含义、功能等的词。一般采用名词。 接口可带I前缀或able、ible、er等后缀。 1.4方法命名规范方法命名规范 方法的命名应采用完整的英文描述符,大小写混合使用:所有中间单词的第一个字母大写。方法名称的第一个单词常常采用一个有强烈动作色彩的动词。 取值类使用get前缀,设值类使用set前缀,判断类使用is(has)前缀。 例: getName() setSarry() isLogon() 方法参数建议顺序:(被操作者,操作内容,操作标志,其他 ) 例:public vo

5、id replace(String sourceStr, String oldStr, String newStr) . 1.5常量常量 采用完整的英文大写单词,在词与词之间用下划线连接,如:DEFAULT_VALUE1.6变量和参数变量和参数 变量建议采用匈牙利命名法,词素规则见“公共约定” 整型变量(包括int,short,long):以 n 开头,例如:longnCredNum; 浮点型变量(包括float,double):以 f 开头,例如:doublefTranAmt; 字符变量:以 c 开头,例如:charcPageFlag; 日期型变量:以d开头,例如:date dToday;

6、布尔型变量:以is开头,例如:boolean isFlag; 字符串变量:以 s 开头,例如:char sPageNo2+1; 全局变量:以g开头结合数据的类型,例如:char gsBankNo10+1; 静态变量:静态变量在文件中同样是全局变量,命名规则同全局变量。 系统级变量:系统级变量同样是全局变量,以 _开头结合数据的类型。例如:char _sBankNo10+1 没有g。 临时变量通常被取名为i,j,k,m和n,它们一般用于整型;c,d,e,它们一般用于字符型。1.7组件组件/部件部件 应采用完整的英文描述符命名组件(接口部件),遵循匈牙利命名法则 如:btnOK,lblName。

7、按钮变量 btn+Xxxxxxx 例如:btnSave, btn Exit, btnPrint等题标变量 lbl+Xxxxxxxx 例如:lblName, lblSex等 对象类型 前缀 Canvas cvs CheckBox chk Image img List lst Choice chc Dialog dlg Event evt Frame frm Menu menu Panel pnl TextArea txa TextField txf1.8集合集合 一个集合,例如数组和矢量,应采用复数命名来表示队列中存放的对象类型。命名应采用完整的英文描述符,名字中所有非开头的单词的第一个字母应大

8、写,适当使用集合缩写前缀。如: Vector vProducts = new Vector(); /产品向量 Array aryUsers = new Array(); /用户列表 1.9神秘的数神秘的数 程序里经常会用到一些量,它是有特定的含义的,把神秘的数定义为一个常量。注意这个常量的命名应该能表达该数的意义,并且应该全部大写,以与对应于变量的标识符区别开来。例如50这个数,可以定义为一个名为NUM_OF_EMPLOYEES的常量来代替。1.10其他其他 命名时应使用复数来表示它们代表多值。如:orderItems。 1.11java异常异常 异常类名由表示该异常类型的单词和Excepti

9、on组成,如ActionException。 异常实例一般使用e、ex等,在多个异常时使用该异常名或简写加E,Ex等组成,如: SQLEx ActionEx 1.12数组命名数组命名 数组应该总是用下面的方式来命名: byte buffer; 而不是 byte buffer;2书写格式规范书写格式规范严格要求书写格式是为了使程序整齐美观、易于阅读、风格统一,程序员对规范书写的必要性要有明确认识。建议源程序使用eclipse工具开发,格式规范预先在工具中设置。2.1缩进缩进缩进建议以4个空格为单位。预处理语句、全局数据、标题、附加说明、函数说明、标号等均顶格书写。语句块的、配对对齐,并与其前一行

10、对齐,语句块类的语句缩进建议每个、单独占一行,便于匹对。sclipse 中的默认方式是开始的不是单独一行,建议更改成上述格式。2.2空格空格原则上变量、类、常量数据和函数在其类型,修饰名称之间适当空格并据情况对齐。关键字原则上空一格,如:if ( . ) 等。运算符的空格规定如下::、-、+、-、!、+、-(指正负号)、&(引用)等几个运算符两边不加空格(其中单目运算符系指与操作数相连的一边),其它运算符(包括大多数二目运算符和三目运算符?:两边均加一空格,在作函数定义时还可据情况多空或不空格来对齐,但在函数实现时可以不用。,运算符只在其后空一格,需对齐时也可不空或多空格。不论是否有括号,对语

11、句行后加的注释应用适当空格与语句隔开并尽可能对齐。个人认为此项可以依照个人习惯决定遵循与否。2.3对齐对齐 原则上关系密切的行应对齐,对齐包括类型、修饰、名称、参数等各部分对齐。另每一行的长度不应超过屏幕太多,必要时适当换行,换行时尽可能在,处或运算符处,换行后最好以运算符打头,并且以下各行均以该语句首行缩进,但该语句仍以首行的缩进为准,即如其下一行为“”应与首行对齐。变量定义最好通过添加空格或TAB键形成对齐,同一类型的变量最好放在一起。如下例所示:int nValue;int nResult;int nLength;2.4空行空行不得存在无规则的空行,比如说连续十个空行。程序文件结构各部分

12、之间空一行,由于每个函数还要有函数说明注释,故通常只需空一行或不空,但对于没有函数说明的情况至少应再空一行。对自己写的函数,建议也加上“/-”做分隔。函数内部数据与代码之间应空至少一行,代码中适当处应以空行空开,建议在代码中出现变量声明时,在其前空一行。类中四个“p”之间至少空一行,在其中的数据与函数之间也应空行。2.5注释注释 注释是软件可读性的具体体现。程序注释量一般占程序编码量的20%,软件工程要求不少于20%。程序注释不能用抽象的语言,类似于处理、循环这样的计算机抽象语言,要精确表达出程序的处理说明。避免每行程序都使用注释,可以在一段程序的前面加一段注释,具有明确的处理逻辑。 注释必不

13、可少,但也不应过多,不要被动的为写注释而写注释。以下是四种必要的注释: (1)标题、附加说明。 (2)函数、类等的说明。对几乎每个函数都应有适当的说明,通常加在函数实现之前,在没有函数实现部分的情况下则加在函数原型前,其内容主要是函数的功能、目的、算法等说明,参数说明、返回值说明等,必要时还要有一些如特别的软硬件要求等说明。公用函数、公用类的声明必须由注解说明其使用方法和设计思路,当然选择恰当的命名格式能够帮助你把事情解释得更清楚。 (3)在代码不明晰或不可移植处必须有一定的说明。 (4)及少量的其它注释,如自定义变量的注释、代码书写时间等。3代码文件风格代码文件风格 所有的 Java(*.j

14、ava) 文件都必须遵守如下的样式规则:3.1文件生成文件生成 对于规范的 JAVA 派生类,尽量用 eclipse工具来生成文件格式,避免用手工制作的头文件/实现文件。3.2package/import package 行要在 import 行之前,import 中标准的包名要在本地的包名之前,而且按照字母顺序排列。如果 import 行中包含了同一个包中的不同子目录,则应该用 * 来处理。 package .stats;import java.io.*;import java.util.Observable;import hotlava.util.Application; 这里 java.

15、io.* 使用来代替InputStream and OutputStream 的。3.3文件头部注释文件头部注释 文件头部注释主要是表明该文件的一些信息,是程序的总体说明,可以增强程序的可读性和可维护性。文件头部注释一般位于 package/imports 语句之后,Class 描述之前。要求至少写出文件名、创建者、创建时间和内容描述。其格式应该尽量约束如下:/*Title: 确定鼠标位置类* Description: 确定鼠标当前在哪个作业栏位中并返回作业号* Copyright: Copyright (c) 2002* Company: HIT* author: rivershan* ve

16、rsion: 1.0*/3.4class 接下来的是类的注释,一般是用来解释类的。 /*A class representing a set of packet and byte counters* It is observable to allow it to be watched, but only* reports changes when the current set is complete*/ 接下来是类定义,包含了在不同的行的 extends 和 implements public class CounterSetextends Observableimplements Clon

17、eable 3.5Class Fields 接下来是类的成员变量: /*Packet counters*/protected int packets; public 的成员变量必须生成文档(JavaDoc)。proceted、private和 package 定义的成员变量如果名字含义明确的话,可以没有注释。3.6存取方法存取方法 接下来是类变量的存取的方法。它只是简单的用来将类的变量赋值获取值的话,可以简单的写在一行上。(个人认为尽量分行写)/*Get the counters* return an array containing the statistical data. This ar

18、ray has been* freshly allocated and can be modified by the caller.*/public int getPackets() return copyArray(packets, offset); public int getBytes() return copyArray(bytes, offset); public int getPackets() return packets; public void setPackets(int packets) this.packets = packets; 其它的方法不要写在一行上3.7构造函

19、数构造函数 接下来是构造函数,它应该用递增的方式写(比如:参数多的写在后面)。 访问类型(public,private 等.)和任何static,final或synchronized应该在一行中,并且方法和参数另写一行,这样可以使方法和参数更易读。 publicCounterSet(int size) this.size = size;3.8克隆方法克隆方法 如果这个类是可以被克隆的,那么下一步就是 clone 方法: publicObject clone()try CounterSet obj = (CounterSet)super.clone();obj.packets = (int)packets.clone();obj.size = size;return obj; catch(CloneNotSupportedException e) throw new InternalError(Unexpected CloneNotSUpportedException: + e.getMessage(); 3.9类方法类方法 下面开始写类的方法: /*Set the packet counters* (such as when restoring

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论