JAVA规则 基本篇
本文介绍的JAVA规则的说明分为5个级别,级别1是最基本也是最重要的级别,在今后将陆续写出其他的规则。遵守了这些规则可以提高程序的效率、使代码有更好的可读性等。
(1) 避免使用NEW关键字来创建String对象。
把一个String常量copy到String 对象中通常是多余、浪费时间的
Public class test{
Public void method(){
System.out.print (str);
}
private String str = new String ("1"); //这里新建对象是完全没有必要的
private String str2=”2” //正确的应该如此
}
参考:Joshua Bloch: "Effective Java - Programming Language Guide"
(2) 避免使用不必要的嵌套。
过多的嵌套会使你的代码复杂化,减弱可读性。
Public class test {
String add (){
Int c=(a=a+b)+b; //过于复杂
Return c
}
}
参考:http://java.sun.com/docs/codeconv/html/CodeConventions.doc9.html#177
(3) 避免在同一行声明不同类型的多个变量
这样可以使程序更加清晰,避免混乱
private int index, index1[];
正确的应该如此:
private int index;
private int index1[];
参考:http://java.sun.com/docs/codeconv/html/CodeConventions.doc5.html#2992
(4) 在每一行里写一条语句
这条规则不包括for语句:比如:'for (int i = 0; i < 10; i++) x--;’可以增加代码的可读性。
public class OSPL {
int method (int a, int b) {
int i = a + b; return i; // 可读性不强
}
正确的:
public class OSPLFixed {
int method (int a, int b) {
int i = a + b;
return i;
}
}
参考:Section 7.1 of http://java.sun.com/docs/codeconv/html/CodeConventions.doc6.html#431
(5)经常从finalize ()中调用super.finalize ()
这里的finalize ()是java在进行垃圾收集的时候调用的,和finally不一样。如果你的父类没有定义finally()的话,你也应该调用。这里有两个原因:(1)在不改变代码的情况下能够将父类的finally方法加到你的类中。 (2)以后你会养成习惯调用父类的finally方法,即使父类没有定义finally方法的时候。
正确的方法应该如此:
public class parentFinalize {
protected void finalize () throws Throwable {
super.finalize(); // FIXED
}
参考:"The Java Programming Language" by Ken Arnold and James Gosling, page 49.
(6) 不要在finalize ()中注销listeners
不要再finalize ()方法中中注销listeners,finalize ()只有再没有对象引用的时候调用,如果listeners从finalize()方法中去除了,被finalize的对象将不会在垃圾收集中去除。
public void finalize () throws Throwable {
bButton.removeActionListener (act);
}
(7) 不要显式的调用finalize ()方法
虽然显式的调用这个方法可以使你确保你的调用,但是当这个方法收集了以后垃圾收集会再收集一次。
- public class T7 {
- public synchronized void release () throws Throwable{
- if (!_released) {
- close_resources (); // do what the old 'finalize ()' did
- _released = true;
- }
- }
- public void finalize () throws Throwable {
- release ();
- super.finalize ();
- }
- public void close_resources() {}
- private boolean _released = false;
- }
- class TestFixed {
- void closeTest () throws Throwable {
- t71 .release (); // FIXED
- t71 = null;
- }
- private T7 t71 = new T7 ();
- }
- public class DUID implements java.io.Serializable {
- public void method () {}
- }
- public class DUIDFixed implements java.io.Serializable {
- public void method () {}
- private static final long serialVersionUID = 1;
- }
- public void method (int j) {
- final int i = 5; // VIOLATION
- }
- private int j = 2;
- public void method (int j1) {
- final int i = 5; // VIOLATION
- }
- private int j = 2;