JAVA书写规范1. 命名 1.1 Package的名字由一个小写单词组成; 一个特有的包的名字的第一部分总是全部使用小写字母, 并应该是顶级域名中的一个,现在有com, edu, gov, mil, net, org, 或者是在ISO标准3166,1981中定义的两个字母的国家标识。 这样的规则可确定某一目录分开的组件,部门,项目,或登陆名 com.sun.eng , com.apple.quicktime.v2 ,org.apache.catalina 1.2 Class/Interface:大写字母开头而其他字母都小写; 类的名字应是名词,混合大小写,每个词的第一个字母大写。 尽量保证你的类的名字简单并是描述性的。使用完整的单词-避免 头字语和缩写(除非缩写比长的格式更广泛使用,例如URL or HTML) class ImageSprite , interface RasterDelegate 1.3 方法应是动词,混合大小写,第一个字母小写,每个内部的词 的第一个字母大写;除了变量,所有的实例、类和类的常量都 是以小写字母开头的混和大小写。内部的词以大写字母开头。 变量名字不应以下划线或美元符$开始,尽管二者都是允许的。 run() ,runFast() , getBackground() 1.4 变量名字应简短但有意义。变量名字的选择应该是可记忆 的---就是说给普通的人指出它的使用的目的,除非是临时的。临时变 量的一般的名字对于整形变量是i,j,k,m,和n,对于字符是c,d,和e。 int i; char c; float myWidth; 1.5 常量:声明类常量的变量和ANSI常量的名字为下划线分开的 大写字母单词(应避免ANSI常量,除非为了调试) static final int MIN_WIDTH = 4; static final int MAX_WIDTH = 999; 2. 文件 2.1 开头:注释(name,version,date,copyright),package,import; /* * Classname * * Version information * * Date * * Copyright notice */ package java.awt; import java.awt.peer.CanvasPeer; 2.2 Class/Interface:JavaDoc文档注释,体(包含程序、运行和其他注释); 变量,实例,方法等:按public,protect,private排列;尽量少用public。 参见最后example 3. 缩进 3.1 避免每行多于80 个字符,逗号后或运算符前断开, someMethod(longExpression1, longExpression2, longExpression3, longExpression4, longExpression5); var = someMethod1(longExpression1, someMethod2(longExpression2, longExpression3)); 3.2 较高级的断开比较低级的断开更好,新行应与同级 上一行的开头对齐;以下是断开算术式的两个例子。 第一个较好,因为断开出现在算术式以外,处于较高一级。 longName1 = longName2 * (longName3 + longName4 - longName5) + 4 * longname6; // PREFER longName1 = longName2 * (longName3 + longName4 - longName5) + 4 * longname6; // AVOID 3.3 缩排的一个单位应使用4 个空格,不使用制表符而尽量使用空格。 通常语句使用8个空格缩进,就要折行,由于传统的(4个空格) 缩进使观察程序体比较难。例如: if ((condition1 && condition2) || (condition3 && condition4) ||!(condition5 && condition6)) { file://BAD WRAPS doSomethingAboutIt(); file://MAKE THIS LINE EASY TO MISS } file://USE THIS INDENTATION INSTEAD if ((condition1 && condition2) || (condition3 && condition4) ||!(condition5 && condition6)) { doSomethingAboutIt(); } 4. 注释,Java程序有两类注释:文档注释和执行注释。 4.1 文档注释只有java具有,/**...*/。能够被javadoc 工具生成HTML文档, 描述类,接口,构造器,方法和字段,相当于使用指南。 /** * Class description goes here. * * @version 1.82 18 Mar 1999 * @author Firstname Lastname */ 4.2 执行注释是那些在使用在C++中的/*...*/和//。目的为了理解程序和运行, 包括不适合于文档注释的内容,块状或一行,使用/*...*/,注释程序可使用//, 也可放在短行后面,尽量对齐。 /* * @(#)Blah.java 1.82 99/03/18 * * Copyright (c) 1994-1999 Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, California, 94303, U.S.A. * All rights reserved. * * This software is the confidential and proprietary information of Sun * Microsystems, Inc. ("Confidential Information"). You shall not * disclose such Confidential Information and shall use it only in * accordance with the terms of the license agreement you entered into * with Sun. */ /* A class implementation comment can go here. */ // implementation comment 5. 声明declaration 5.1 每行一个声明,加以注释; int level; // indentation level int size; // size of table 5.2 不要在同一行放置不同的类型; int foo, fooarray[]; file://WRONG! 5.3 只在块的开始处,放置声明; 第一次使用时再声明,增强代码的可移植性。 if (condition) { int int2 = 0; // beginning of "if" block ... } for (int i = 0; i < maxLoops; i++) { ... } 5.4 方法后紧跟"(" ,"{"出现在行尾。 Sample(int i, int j) { ivar1 = i; ivar2 = j; } 6. 语句 6.1 每行最多包括一个语句; argv++; // Correct argc--; // Correct argv++; argc--; // AVOID! if (condition) { statements; } else { statements; } for (initialization; condition; update) { statements; } 6.2 比较重要的一个: try { statements; }catch (ExceptionClass e) { statements; } 7. 空格 7.1 利用空行分隔代码段来提高可读性; 7.2 使用空行:类,接口,方法之间,在一个方法的本地变量和它的第一个语句间; 7.3 被一个圆括号跟着的关键字应被一个空格所分开, 例"while (true) { ", 但方法不分开。 7.4 参数列表中的逗号之后使用一个空格。 public void doSomethingElse(Object someParam, String twoParam) 7.5 二进制的操作符与数以空格分开,例"a = (a + b) / (c * d);" 。 8. 其它 8.1 避免使用一个对象来访问一个类的(静态)变量或方法。 而是使用一个类的名字; classMethod(); file://OK AClass.classMethod(); file://OK anObject.classMethod(); file://AVOID! 8.2 避免分配多个变量给同样值在一个单独的语句中; fooBar.fChar = barFoo.lchar = 'c'; // AVOID! 8.3 适当使用()和{}来分隔运算和程序。 9. 性能有关 (优化代码,调试,运行) 避免太多的使用 synchronized 关键字 ; 尽量使用 StringBuffer 对象; 尽量不要混合使用AWT 和 Swing 组件,等等。 下面是一个参考范例。 /* * @(#)Blah.java 1.82 99/03/18 * * Copyright (c) 1994-1999 Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, California, 94303, U.S.A. * All rights reserved. * * This software is the confidential and proprietary information of Sun * with Sun..... */ package java.blah; import java.blah.blahdy.BlahBlah; /** * Class description goes here. * * @version 1.82 18 Mar 1999 * @author Firstname Lastname */ public class Blah extends SomeClass { /* 执行注释. */ /** classVar1 文档注释*/ public static int classVar1; /** * classVar2 多于一行的文档注释 * 注释 */ private static Object classVar2; /** instanceVar1 文档注释 */ public Object instanceVar1; /** instanceVar2 文档注释 */ protected int instanceVar2; /** instanceVar3 文档注释 */ private Object[] instanceVar3; /** * ...构造器 Blah 文档注释... */ public Blah() { // ...执行注释 goes here... } /** * ...方法 doSomething 文档注释... */ public void doSomething() { // ...执行注释 goes here... } /** * ...方法 doSomethingElse文档注释.. * @param someParam参数描述 */ public void doSomethingElse(Object someParam) { // ...执行注释goes here... } }
|