Java程序性能优化(1)

简介:
后面几条似乎有点不那么必要?
一、避免在循环条件中使用复杂表达式
  在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快。
  例子:
  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
  }
  }
  }
 
更正:
  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];
  System.arraycopy(array1, 0, array2, 0, 100);
  }
  }
  参考资料:
  五、让访问实例内变量的getter/setter方法变成”final”
  简单的getter/setter方法应该被置成final,这会告诉编译器,这个方法不会被重载,所以,可以变成”inlined”
  例子:
  class MAF {
  public void setSize (int size) {
  _size = size;
  }
  private int _size;
  }
  更正:
  class DAF_fixed {
  final public void setSize (int size) {
  _size = size;
  }
  private int _size;
  }
  参考资料:
  Warren N. and Bishop P. (1999), "Java in Practice", p. 4-5
  Addison-Wesley, ISBN 0-201-36065-9
  六、避免不需要的instanceof操作
  如果左边的对象的静态类型等于右边的,instanceof表达式返回永远为true。
  例子:
  public class UISO {
  public UISO () {}
  }
  class Dog extends UISO {
  void method (Dog dog, UISO u) {
  Dog d = dog;
  if (d instanceof UISO) // always true.
  System.out.println("Dog is a UISO");
  UISO uiso = u;
  if (uiso instanceof Object) // always true.
  System.out.println("uiso is an Object");
  }
  }
  更正:
  删掉不需要的instanceof操作。
  class Dog extends UISO {
  void method () {
  Dog d;
  System.out.println ("Dog is an UISO");
  System.out.println ("UISO is an UISO");
  }
  }
  七、避免不需要的造型操作
  所有的类都是直接或者间接继承自Object。同样,所有的子类也都隐含的“等于”其父类。那么,由子类造型至父类的操作就是不必要的了。
  例子:
  class UNC {
  String _id = "UNC";
  }
  class Dog extends UNC {
  void method () {
  Dog dog = new Dog ();
  UNC animal = (UNC)dog;  // not necessary.
  Object o = (Object)dog;         // not necessary.
  }
  }
  更正:
  class Dog extends UNC {
  void method () {
  Dog dog = new Dog();
  UNC animal = dog;
  Object o = dog;
  }
  }
  参考资料:
  Nigel Warren, Philip Bishop: "Java in Practice - Design Styles and Idioms
  for Effective Java".  Addison-Wesley, 1999. pp.22-23
相关文章
|
9月前
|
人工智能 监控 安全
智慧工地解决方案,java智慧工地程序代码
智慧工地系统融合物联网、AI、大数据等技术,实现对施工现场“人、机、料、法、环”的全面智能监控与管理,提升安全、效率与决策水平。
254 2
|
7月前
|
安全 Java
Java异常处理:程序世界的“交通规则
Java异常处理:程序世界的“交通规则
382 98
|
8月前
|
存储 Java 编译器
对比Java学习Go——程序结构与变量
本节对比了Java与Go语言的基础结构,包括“Hello, World!”程序、代码组织方式、入口函数定义、基本数据类型及变量声明方式。Java强调严格的面向对象结构,所有代码需置于类中,入口方法需严格符合`public static void main(String[] args)`格式;而Go语言结构更简洁,使用包和函数组织代码,入口函数为`func main()`。两种语言在变量声明、常量定义、类型系统等方面也存在显著差异,体现了各自的设计哲学。
289 0
|
11月前
|
Java 物联网 数据处理
Java Solon v3.2.0 史上最强性能优化版本发布 并发能力提升 700% 内存占用节省 50%
Java Solon v3.2.0 是一款性能卓越的后端开发框架,新版本并发性能提升700%,内存占用节省50%。本文将从核心特性(如事件驱动模型与内存优化)、技术方案示例(Web应用搭建与数据库集成)到实际应用案例(电商平台与物联网平台)全面解析其优势与使用方法。通过简单代码示例和真实场景展示,帮助开发者快速掌握并应用于项目中,大幅提升系统性能与资源利用率。
297 6
Java Solon v3.2.0 史上最强性能优化版本发布 并发能力提升 700% 内存占用节省 50%
|
10月前
|
存储 监控 算法
企业上网监控场景下布隆过滤器的 Java 算法构建及其性能优化研究
布隆过滤器是一种高效的数据结构,广泛应用于企业上网监控系统中,用于快速判断员工访问的网址是否为违规站点。相比传统哈希表,它具有更低的内存占用和更快的查询速度,支持实时拦截、动态更新和资源压缩,有效提升系统性能并降低成本。
416 0
|
12月前
|
存储 安全 Java
【高薪程序员必看】万字长文拆解Java并发编程!(4-1):悲观锁底层原理与性能优化实战
目录4. JVM字节码文件4.1. 字节码文件-组成4.1.1. 组成-基础信息4.1.1.1. 基础信息-魔数4.1.1.2. 基础信息-主副版本号4.1.2. 组成-常量池4.1.3. 组成-方法4.1.3.1. 方法-工作流程4.1.4. 组成-字段4.1.5. 组成-属性4.2. 字节码文件-查看工具4.2.1. javap4.2.2. jclasslib4.2.3. 阿里Arthas
203 0
|
Java C语言
课时8:Java程序基本概念(标识符与关键字)
课时8介绍Java程序中的标识符与关键字。标识符由字母、数字、下划线和美元符号组成,不能以数字开头且不能使用Java保留字。建议使用有意义的命名,如student_name、age。关键字是特殊标记,如蓝色字体所示。未使用的关键字有goto、const;特殊单词null、true、false不算关键字。JDK1.4后新增assert,JDK1.5后新增enum。
251 4
|
Java 编译器
课时7:Java程序基本概念(注释)
课时7介绍了Java程序中的注释。编程语言有其语法和语义,注释有助于理解代码需求,防止断档。Java支持三类注释:单行(//)、多行(/* */)和文档注释(/** */)。注释不会被编译器编译。范例中展示了如何在代码中使用注释,并强调了注释对项目文档管理的重要性。
310 3