Java 性能优化问题
目录
Java 性能优化
问题 ........................................................................................................................... 1 1. 避免在循环条件中使用复杂表达式 ............................................................................... 2 2. 为'Vectors' 和 'Hashtables'定义初始大小...................................................................... 3 3. 在 finally 块中关闭 Stream .............................................................................................. 4 4. 使用'System.arraycopy ()'代替通过来循环复制数组 ..................................................... 5 5. 让访问实例内变量的 getter/setter 方法变成”final”.................................................... 6 6. 避免不需要的 instanceof 操作 ........................................................................................ 7 7. 避免不需要的造型操作 ................................................................................................... 8
一、 避免在循环条件中使用复杂表达式
在不做编译优化的情况下, 在循环中, 循环条件会被反复计算, 如果不使用复杂表达式, 而使循环条件值不变的话,程序将会运行的更快。 例子: import java.util.Vector; class CEL { void method (Vector vector) { for (int i = 0; i < vector.size (); i++) // Violation ; // ... } } 更正: class CEL_fixed { void method (Vector vector) { int size = vector.size () for (int i = 0; i < size; i++) ; // ... } }
二、 为'Vectors' 和 'Hashtables'定义初始大小 定义初始大小
JVM 为 Vector 扩充大小的时候需要重新创建一个更大的数组,将原原先数组中的内容 复制过来,最后,原先的数组再被回收。可见 Vector 容量的扩大是一个颇费时间的事。 通常,默认的 10 个元素大小是不够的。你最好能准确的估计你所需要的最佳大小。 例子: import java.util.Vector; public class DIC { public void addObjects (Object[] o) { // if length > 10, Vector needs to expand for (int i = 0; i< o.length;i++) { v.add(o); } } public Vector v = new Vector(); // no initialCapacity. } 更正: 自己设定初始大小。 public Vector v = new Vector(20); public Hashtable hash = new Hashtable(10); 参考资料: Dov Bulka, "
Java Performance and Scalability Volume 1: Server-Side Programming Techniques" Addison Wesley, ISBN: 0-201-70429-3 pp.55 – 57 // capacity before it can add more elements.
三、 在 finally 块中关闭 Stream
程序中使用到的资源应当被释放,以避免资源泄漏。这最好在 finally 块中去做。不管程 序执行的结果如何,finally 块总是会执行的,以确保资源的正确关闭。 例子: import java.io.*; public class CS { public static void main (String args[]) { CS cs = new CS (); cs.method (); } public void method () { try { FileInputStream fis = new FileInputStrea
m ("CS.java"); int count = 0; while (fis.read () != -1) count++; System.out.println (count); fis.close (); } catch (FileNotFoundException e1) { } catch (IOException e2) { }
} } 更正: 在最后一个 catch 后添加一个 finally 块 参考资料: Peter Haggar: "Practical Java - Programming Language Guide". Addison Wesley, 2000, pp.77-79
使用'System.arraycopy ()'代替通过来循环复制数组 四、 使用 代替通过来循环复制数组
'System.arraycopy ()' 要比通过循环来复制数组快的多。 例子: public class IRB { void method () { int[] array1 = new int [100]; for (int i = 0; i < array1.length; i++) { array1 [i] = i; } int[] array2 = new int [100