FreeMan

Java是条不归路……

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  4 随笔 :: 1 文章 :: 2 评论 :: 0 Trackbacks

JAVA书写规范

(这条文章已经被阅读了364次) 时间:2002年03月08日 18:59 来源:韩伟 原创-IT

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...

}

}

posted on 2007-07-25 14:49 我的Java工作经历 阅读(588) 评论(1)  编辑  收藏

评论

# re: 转帖:Java书写规范[未登录] 2009-02-18 16:12 Java
不错  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航: