[计算机软件及应用]java性能优化笔记.pdfVIP

  • 4
  • 0
  • 约3.99万字
  • 约 43页
  • 2018-02-17 发布于浙江
  • 举报

[计算机软件及应用]java性能优化笔记.pdf

[计算机软件及应用]java性能优化笔记

Java性能优化笔记 1. new 用 关键词创建类的实例时,构造函数链中的所有构造函数都会被自动调用。但如果一个 对象实现了Cloneable接口,我们可以调用它的clone()方法。clone()方法不会调用任何类构 造函数。 在使用设计模式(Design Pattern)的场合,如果用Factory模式创建对象,则改用clone() 方法创建新的对象实例非常简单。例如,下面是 Factory模式的一个典型实现: public static Credit getNewCredit() {return new Credit();} 改进后的代码使用clone()方法,如下所示: private static Credit BaseCredit = new Credit();public static Credit getNewCredit() {return (Credit) BaseCredit.clone();} 面的思路对于数组处理同样很有用。 2. 使用非阻塞I/O 版本较低的JDK不支持非阻塞I/O API。为避免I/O阻塞,一些应用采用了创建大量线程的办 法(在较好的情况下,会使用一个缓冲池)。这种技术可以在许多必须支持并发 I/O流的应用 中见到,如Web服务器、报价和拍卖应用等。然而,创建Java线程需要相当可观的开销。 3. 慎用异常 异常对性能不利。抛出异常首先要创建一个新的对象。Throwable接口的构造函数调用名为 fillInStackTrace()的本地(Native)方法,fillInStackTrace()方法检查堆栈,收集调用跟踪 VM 信息。只要有异常被抛出, 就必须调整调用堆栈,因为在处理过程中创建了一个新的对象。 异常只能用于错误处理,不应该用来控制程序流程。 4. 不要重复初始化变量 默认情况下,调用类的构造函数时, Java会把变量初始化成确定的值:所有的对象被设置成 null byte short int long 0 float double 0.0 ,整数变量( 、 、 、 )设置成 , 和 变量设置成 ,逻 辑值设置成false。当一个类从另一个类派生时,这一点尤其应该注意,因为用 new关键词创 建一个对象时,构造函数链中的所有构造函数都会被自动调用。 5. 尽量指定类的final修饰符 带有final修饰符的类是不可派生的。在Java核心API中,有许多应用final的例子,例如 java.lang.String。为String类指定final防止了人们覆盖length()方法。另外,如果指定一 final final Java inline final 个类为 ,则该类所有的方法都是 。 编译器会寻找机会内联( )所有的 方法(这和具体的编译器实现有关)。此举能够使性能平均提高 50%。 6. 尽量使用局部变量 调用方法时传递的参数以及在调用中创建的临时变量都保存在栈(Stack)中,速度较快。其他 变量,如静态变量、实例变量等,都在堆(Heap)中创建,速度较慢。另外,依赖于具体的编 译器/JVM,局部变量还可能得到进一步优化。 7. 乘法和除法 考虑下面的代码: for (val = 0; val 100000; val +=5) { alterX = val * 8; myResult = val * 2; } 用移位操作替代乘法操作 可以极大地提高性能。下面是修改后的代码:for(val= 0; val 100000; val += 5) { alterX = val 3; myResult = val 1; } 8 3 1 2 修改后的代码不再做乘以 的操作,而是改用等价的

文档评论(0)

1亿VIP精品文档

相关文档