[转载]细细讲述Java技术开发的规则之基本篇

细细讲述Java技术开发的规则之基本篇
本文介绍的Java规则的说明分为5个级别,级别1是最基本也是最重要的级别,在今后将陆续写出其他的规则。遵守了这些规则可以提高程序的效率、使代码有更好的可读性等。

(1)避免使用NEW关键字来创建S tring对象。

把一个String常量copy到String 对象中通常是多余、浪费时间的:



Public class test
{
  Public void method()
  {
    System.out.print (str);
}
private String str = new String ("1"); 
//这里新建对象是完全没有必要的
private String str2=”2” 
//正确的应该如此
}


(2)避免使用不必要的嵌套。

过多的嵌套会使你的代码复杂化,减弱可读性。

Public class test
{
   String add ()
   {
Int c=(a=a+b)+b;
//过于复杂
Return c
}
}


(3)避免在同一行声明不同类型的多个变量

这样可以使程序更加清晰,避免混乱:

private int index, index1[];


正确的应该如此:

private int index;  
private int index1[];


(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;  
    }
}


(5)经常从finalize ()中调用super.finalize ()

这里的finalize()是Java在进行垃圾收集的时候调用的,和finally不一样。如果你的父类没有定义finally()的话,你也应该调用。这里有两个原因:

1、在不改变代码的情况下能够将父类的finally方法加到你的类中。 2、以后你会养成习惯调用父类的finally方法,即使父类没有定义finally方法的时候。

正确的方法应该如此:

public class parentFinalize
{
    protected void finalize () throws Throwable 
	{
        super.finalize();
		// FIXED   
    }


(6)不要在finalize ()中注销listeners

不要再finalize()方法中中注销listeners,finalize()只有再没有对象引用的时候调用,如果listeners从finalize()方法中去除了,被finalize的对象将不会在垃圾收集中去除。

public void finalize () throws Throwable
{
        bButton.removeActionListener (act);  
    }


(7)不要显式的调用finalize()方法

虽然显式的调用这个方法可以使你确保你的调用,但是当这个方法收集了以后垃圾收集会再收集一次。

public class T7 
{ 
    public void finalize() throws Throwable
	{ 
        close_resources (); 
        super.finalize (); 
    } 
    public void close_resources() 
	{
	} 
} 

class Test
{ 
    void cleanup () throws Throwable
	{ 
        t71.finalize(); 
		// 调用 
        t71 = null; 
    } 
    private t71 = new T7 (); 
}


对于这样的调用我们应该自己创建一个释放的方法,做最初finalize()所作的事情,当你每次想显式的调用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 (); 
}


(8)不要使用不推荐的API

尽量使用JDK1.3推荐的API。在类和方法或者java组件里有很多方法是陈旧的或者是可以选择的。有一些方法SUN用了"deprecated“标记。最好不要使用例如:

private List t_list = new List ();
 t_list.addItem (str);


如果查一下javadoc的话,会发现建议用add()来代替addItem()。

(9)为所有序列化的类创建一个'serialVersionUID'

可以避免从你各种不同的类破坏序列的兼容性。如果你不特别制订一个UID的话,那么系统为自动产生一个UID(根据类的内容)。如果UID在你新版本的类中改变了,即使那个被序列化的类没改变,你也不能反序列化老的版本了。

public class DUID implements 
java.io.Serializable
{   
    public void method () 
	{
	} 
}


在里面加一个UID,当这个类的序列化形式改变的时候,你也改变这个UID就可以了。

public class DUIDFixed implements 
java.io.Serializable 
{ 
    public void method ()
	{
	} 
    private static final 
	long serialVersionUID = 1;  
}


(10)对于private常量的定义

比较好的做法是对于这样的常量,加上final标记,这样的常量从初始化到最后结束值都不会改变。

private int size = 5;


改变后的做法是:

private final int size = 5;


(11)避免把方法本地变量和参数定义成和类变量相同的名字。

这样容易引起混扰,建议把任何的变量字都定义成唯一的。这样看来,SCJP里的那些题目在现实中就用不到了:

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;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/374079/viewspace-130937/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/374079/viewspace-130937/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值