电话:0731-83595998
导航

Java程序性能优化(1)

来源: 2017-12-13 14:23

 一、避免在循环条件中使用复杂表达式

  在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快。

  例子

  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);   // capacity before it can add more elements.

  }

  }

  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

  三、在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 FileInputStream ("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];

  for (int i = 0; i < array2.length; i++) {

  array2 [i] = array1 [i];        // Violation

  }

  }

编辑推荐:

下载Word文档

温馨提示:因考试政策、内容不断变化与调整,长理培训网站提供的以上信息仅供参考,如有异议,请考生以权威部门公布的内容为准! (责任编辑:长理培训)

网络课程 新人注册送三重礼

已有 22658 名学员学习以下课程通过考试

网友评论(共0条评论)

请自觉遵守互联网相关政策法规,评论内容只代表网友观点!

最新评论

点击加载更多评论>>

精品课程

更多
10781人学习

免费试听更多

相关推荐
图书更多+
  • 电网书籍
  • 财会书籍
  • 其它工学书籍
拼团课程更多+
  • 电气拼团课程
  • 财会拼团课程
  • 其它工学拼团
热门排行

长理培训客户端 资讯,试题,视频一手掌握

去 App Store 免费下载 iOS 客户端