1. private static Credit BaseCredit = new Credit();
2. public static Credit getNewCredit() {
3. return (Credit) BaseCredit.clone();
4. }
private static Credit BaseCredit = new Credit();
public static Credit getNewCredit() {
return (Credit) BaseCredit.clone();
}
Java语言习惯用语
1.循环
■ 在重要的循环里,消除循环终止判断时的方法调用。。。
例如:将...bt www.bt285.cn
for(int i=0; i<collection.size();i++){
1. ...
2. }
for(int i=0; i<collection.size();i++){
...
}
替换为…
1. for(int i=0; n=collection.size();i<n;i++){
2. ...
3. }
for(int i=0; n=collection.size();i<n;i++){
...
}
■ 通常,把与循环index不相关的移到循环的外面
1. for(int i=0; terminal=x.length;i<terminal;i++){
2. x[i] = x[i]/scaleA *scaleB;
3. }
for(int i=0; terminal=x.length;i<terminal;i++){
x[i] = x[i]/scaleA *scaleB;
}
应该该成:
1. Double scale = scaleB*scaleA;
2. for(int i=0; terminal=x.length;i<terminal;i++){
3. x[i] = x[i]/scale ;
4. }
Double scale = scaleB*scaleA;
for(int i=0; terminal=x.length;i<terminal;i++){
x[i] = x[i]/scale ;
}
2.字符串
■ 消除字符串连接
■ 创建长字符串时,总是使用StringBuffter代替String
■ 预先分配StringBuffer空间 StringBuffer sb = new StringBuffer(5000);
3.基本数据类型
■ 在重要的循环里使用基本数据类型(int型数据通常比long/double型数据更快)
■ 基本数据类型(Boolean,Integer,etc)的包装类主要用在当传递的方法参数必须是一个对象的引用时(而不是一个基本数据类型)
■ 对所有的常量代数表达式使用static final修饰符
■ 使常量更容易引用(编译器预先计算常量表达式)
4.异常
■ 异常只用于单个真正的错误条件 如小说520网 www.5a520.cn 抛出异常时
抛出一个异常和执行一个catch代码块花费是很高的(主要由于当创建一个异常时要获得线程栈的一个快照)
只当条件真的异常时才抛出一个异常
■ 抛出异常首先要创建一个新的对象。
Throwable接口的构造函数调用名为fillInStackTrace()的本地(Native)方法,fillInStackTrace()方法检查堆栈,收集调用跟踪信息。
只要有异常被抛出,VM就必须调整调用堆栈,因为在处理过程中创建了一个新的对象。
异常只能用于错误处理,不应该用来控制程序流程。
■ 使编译器和运行时最优化,将几个方法调用放在一个try/catch块中,而不是为每个方法调用实现几个try/catch块
1. try{
2. Some.method1(); //Difficut for java1.4
3. }catch(method1Exception e){
4. handle exception 1 // to optimize this code
5. }
6.
7. try{
8. Some.method2(); //Difficut for java1.4
9. }catch(method2Exception e){
10. handle exception 2 // to optimize this code
11. }
12.
13. try{
14. Some.method3(); //Difficut for java1.4
15. }catch(method3Exception e){
16. handle exception 3 // to optimize this code
17. }
try{
Some.method1(); //Difficut for java1.4
}catch(method1Exception e){
handle exception 1 // to optimize this code
}
try{
Some.method2(); //Difficut for java1.4
}catch(method2Exception e){
handle exception 2 // to optimize this code
}
try{
Some.method3(); //Difficut for java1.4
}catch(method3Exception e){
handle exception 3 // to optimize this code
}
应该写为:
1. try{
2. Some.method1();
3. Some.method2();
4. Some.method3(); //Difficut for java1.4
5. }catch(method1Exception e){
6. handle exception 1
7. }catch(method2Exception e){
8. handle exception 2
9. }catch(method3Exception e){
10. handle exception 3
11. }
try{
Some.method1();
Some.method2();
Some.method3(); //Difficut for java1.4
}catch(method1Exception e){
handle exception 1
}catch(method2Exception e){
handle exception 2
}catch(method3Exception e){
handle exception 3
}
5.基准
■ 注意,所有这些技巧会因不同的平台和虚拟机而不同
一 例如:在有些servlet容器内,通过一个OutputStream作为字节输出会更快
一 在其它的容器内,通过一个PrintWriter输出字符会更快
■ 这些技巧描述的是最可移植的建议
■ 你可能需要运行一些基准来判断在你的平台上怎么样是最快的
6.不用new关键词创建类的实例
■用new关键词创建类的实例时,构造函数链中的所有构造函数都会被自动调用。
但如果一个对象实现了Cloneable接口,我们可以调用它的clone()方法。clone()方法不会调用任何类构造函数。
在使用设计模式(Design Pattern)的场合,如果用Factory模式创建对象,则改用clone()方法创建新的对象实例非常简单。
例如,下面是Factory模式的一个典型实现:
1. public static Credit getNewCredit() {
2. return new Credit();
3. }
public static Credit getNewCredit() {
return new Credit();
}
优化后:
1. private static Credit BaseCredit = new Credit();
2. public static Credit getNewCredit() {
3. return (Credit) BaseCredit.clone();
4. }
private static Credit BaseCredit = new Credit();
public static Credit getNewCredit() {
return (Credit) BaseCredit.clone();
}
上面的思路对于数组处理同样很有用。
7.使用非阻塞I/O
■Java版本较低的JDK不支持非阻塞I/O API。为避免I/O阻塞,一些应用采用了创建大量线程的办法(在较好的情况下,会使用一个缓冲池)。这种技术可以在许多必须支持并发I/O流的应用中见到,如Web服务器、报价和拍卖应用等。然而,创建Java线程需要相当可观的开销。
JDK 1.4引入了非阻塞的I/O库(java.nio)。如果应用要求使用版本较早的JDK,在这里有一个支持非阻塞I/O的软件包。
8.不要重复初始化变量
■默认情况下,调用类的构造函数时, Java会把变量初始化成确定的值:所有的对象被设置成null,整数变量(byte、short、int、long)设置成0,float和 double变量设置成0.0,逻辑值设置成false。
当一个类从另一个类派生时,这一点尤其应该注意,因为用new关键词创建一个对象时,构造函数链中的所有构造函数都会被自动调用。
9.尽量指定类的final修饰符
■带有final修饰符的类是不可派生的。在Java核心API中,有许多应用final的例子,例如java.lang.String。为String类指定final防止了人们覆盖length()方法。
另外,如果指定一个类为final,则该类所有的方法都是final。Java编译器会寻找机会内联(inline)所有的final方法(这和具体的编译器实现有关)。此举能够使性能平均提高50%。
10.尽量使用局部变量
■调用方法时传递的参数以及在调用中创建的临时变量都保存在栈(Stack)中,速度较快。其他变量,如静态变量、实例变量等,都在堆(Heap)中创建,速度较慢。另外,依赖于具体的编译器/JVM,局部变量还可能得到进一步优化。请参见《尽可能使用堆栈变量》。
11.乘法和除法
■考虑下面的代码:
1. for (val = 0; val < 100000; val +=5) { alterX = val * 8; myResult = val * 2; }
for (val = 0; val < 100000; val +=5) { alterX = val * 8; myResult = val * 2; }
优化后:
1. for (val = 0; val < 100000; val += 5) { alterX = val << 3; myResult = val << 1; }
for (val = 0; val < 100000; val += 5) { alterX = val << 3; myResult = val << 1; }
修改后的代码不再做乘以8的操作,而是改用等价的左移3位操作,每左移1位相当于乘以2。相应地,右移1位操作相当于除以2。值得一提的是,虽然移位操作速度快,但可能使代码比较难于理解,所以最好加上一些注释。
分享到:
相关推荐
Java性能优化是IT行业中至关重要的一个领域,尤其是在大型企业级应用和互联网服务中,高效的Java代码能够显著提升系统运行效率,降低服务器资源消耗。以下是对这四本经典书籍中的核心知识点的详细介绍: 1. **...
Java性能调优是一个复杂而重要的领域,涉及到程序的运行效率、资源消耗以及系统的稳定性。这份“Java性能调优大全”提供了全面的指南,包括VisualVM的使用、JVM的性能优化、OMM(可能是指Oracle Management Monitor...
阿里巴巴Java性能调优实战(2021华山版) 本资源摘要信息来自阿里巴巴Java性能调优实战(2021华山版),旨在帮助Java开发者掌握性能调优的实战经验和技术。 性能调优的重要性 性能调优是软件开发中一个非常重要的...
以下是一些常用的Java性能调优命令及其用法和相关知识点。 1. jps命令用于列出所有的JVM实例。通过该命令,开发者可以快速查看本机上所有Java应用程序的进程ID。例如,使用`jps`可以列出本机所有的JVM实例。 2. ...
Java性能分析是优化Java应用程序的关键步骤,它涉及监控和理解应用程序在运行时的资源消耗,如CPU使用率、内存分配、线程活动等。Performance Analyzer是一款专门针对Java性能的工具,它提供了深入洞察应用程序性能...
《Java性能权威指南》是一本深入探讨Java平台性能优化的专业书籍。这本书全面涵盖了从JVM(Java虚拟机)内部机制到应用程序级别的各种性能问题,旨在帮助开发者和系统管理员理解并解决Java应用程序中的性能瓶颈。 ...
《大话JAVA性能优化》这份文档深入探讨了Java程序在多个层面的性能调优策略,旨在帮助开发者提高程序运行效率,降低资源消耗,提升用户体验。以下是对这些知识点的详细阐述: 1. **代码层次优化**:在代码编写阶段...
总的来说,Java性能优化涉及代码质量、JVM配置、并发处理、IO操作等多个方面。通过深入理解和实践,我们可以打造出更高效、更稳定的Java应用程序。这个"JAVA优化编程"PDF教程将引导你逐步掌握这些核心技巧,助你在...
本资料集锦主要涵盖了Java性能优化的多个方面,包括但不限于代码优化、内存管理、系统设计与优化等关键领域。 一、Java程序性能优化(23条) 1. **避免过度使用反射**:反射在某些场景下很有用,但其开销较大,应...
4. **代码级性能探查**:JProbe允许在代码级别进行性能分析,可以查看每个方法的调用次数、执行时间和资源消耗,这对于定位性能瓶颈非常有帮助。 5. **JVM监控**:JProbe还可以监控JVM的运行状态,包括类加载、垃圾...
根据给定材料中的内容,我们可以了解到Java虚拟机性能监控涉及到了多个层面的工具,包括但不限于: - **网络管理系统**:用于监控网络设备的状态,如路由器、交换机等。 - **操作系统监控工具**:例如`vmstat`、`...
综上所述,Java性能测试与调优是一个涉及多个方面的复杂过程,需要考虑JVM配置、应用服务器设置、数据库性能监控以及代码层面的优化。通过细致地分析和调整,可以显著提高Java应用程序的性能和响应速度。文档中的...
在这个"MAT Eclipse MemoryAnalyzer java性能分析"主题中,我们将深入探讨MAT的核心功能、使用方法以及如何通过它来提升Java应用的性能。 MAT提供了丰富的视图和功能,帮助开发者识别内存问题。其中,最重要的可能...
Java性能优化是软件开发中的一个关键领域,尤其是在大型企业级应用和高并发系统中。《Java性能优化》一书深入探讨了如何通过各种技术提升Java应用程序的效率和响应速度。以下是一些基于书籍源码和相关文件名的关键...
5. **Switch语句的default分支**:在每个switch语句中包含default分支,确保所有可能的条件都得到处理,提高代码的健壮性。 6. **避免字符串字面量的重复定义**:如果一个字符串在多处被使用,应将其定义为常量,以...
Java性能监控是针对Java应用程序的性能分析和优化过程,目的是确保程序运行高效,资源使用合理。在Java环境中,性能监控通常包括CPU使用率、内存使用情况、线程状态、垃圾回收(Garbage Collection)行为等多个方面...
总的来说,优化Java性能需要在设计和编码阶段就考虑到资源的使用、内存管理、并发控制等多个方面。理解并合理运用这些细节,有助于编写出更加高效、资源友好的代码。在实际开发中,还可以借助各种工具和库进行性能...
Java反射机制是Java编程语言中一个强大的特性,它允许程序在运行时动态地访问、检测和修改类、接口、字段和方法等对象。然而,反射操作通常会引入额外的开销,这在性能敏感的应用场景下可能成为一个瓶颈。本文将深入...
在IT行业中,Java性能分析是优化应用程序的关键环节,它涉及到如何有效地使用系统资源,提高程序运行效率,并确保软件系统的稳定性。本主题将深入探讨Java性能分析的相关知识点,结合标签"源码"和"工具",我们将关注...