井一

人走昨日黄花,套中人在吃瓜

2,(非原创-点)如何较高效的实现Java代码优化

1,尽量避免用new来创建String对象。


Public class test{

 Public void method(){

  System.out.print (str);

 }

 private String str = new String ("1"); //这里新建对象是完全没有必要的

 private String str2=”2”; //正确的应该如此

}

——————————————————————————————

2,避免使用不必要的嵌套,即代码语句最好用单句;


——————————————————————————————

3,避免在同一行声明多个变量,可以让代码清晰:


private int index, index1[];

//明显下面的更清晰  

private int index;

private int index1[];


——————————————————————————————

4,经常从finalize ()中调用super.finalize ()

它和finally不一样,如果你的父类没有定义finally()的话,你也应该调用。这里有两个原因:(1)在不改变代码的情况下能够将父类的finally方法加到你的类中。 (2)以后你会养成习惯调用父类的finally方法,即使父类没有定义finally方法的时候。


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


————————————————————————————

5,不要在finalize ()中注销listeners

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


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


——————————————————————————————

6,不要显式的调用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 ();


——————————————————————————————

7不要使用不推荐的API

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

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

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


——————————————————————————————

8,为所有序列化的类创建一个'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;


——————————————————————————————

9,对于private常量的定义

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

private int size = 5; 
  改变后的做法是:

private final int size = 5; 


——————————————————————————————

10,避免把方法本地变量和参数,定义成和类变量相同的名字

  这样容易引起混扰,建议把任何的变量字都定义成唯一的。这样看来,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;


————————                over                           —————————

评论