Java语言习惯用语
1.循环
■ 在重要的循环里,消除循环终止判断时的方法调用。。。
例如:将...
Java代码
-
for(int i=0; i<collection.size();i++){
- ...
- }
替换为…
Java代码
-
for(int i=0; n=collection.size();i<n;i++){
- ...
- }
■ 通常,把与循环index不相关的移到循环的外面
Java代码
-
for(int i=0; terminal=x.length;i<terminal;i++){
- x[i] = x[i]/scaleA *scaleB;
- }
应该该成:
Java代码
- 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.异常
■ 异常只用于单个真正的错误条件
抛出一个异常和执行一个catch代码块花费是很高的(主要由于当创建一个异常时要获得线程栈的一个快照)
只当条件真的异常时才抛出一个异常
■ 抛出异常首先要创建一个新的对象。
Throwable接口的构造函数调用名为fillInStackTrace()的本地(Native)方法,fillInStackTrace()方法检查堆栈,收集调用跟踪信息。
只要有异常被抛出,VM就必须调整调用堆栈,因为在处理过程中创建了一个新的对象。
异常只能用于错误处理,不应该用来控制程序流程。
■ 使编译器和运行时最优化,将几个方法调用放在一个try/catch块中,而不是为每个方法调用实现几个try/catch块
Java代码
-
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
- }
应该写为:
Java代码
-
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模式的一个典型实现:
Java代码
-
public static Credit getNewCredit() {
- return new Credit();
- }
优化后:
Java代码
-
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.乘法和除法
■考虑下面的代码:
Java代码
-
for (val = 0; val < 100000; val +=5) { alterX = val * 8; myResult = val * 2; }
优化后:
Java代码
-
for (val = 0; val < 100000; val += 5) { alterX = val << 3; myResult = val << 1; }
修改后的代码不再做乘以8的操作,而是改用等价的左移3位操作,每左移1位相当于乘以2。相应地,右移1位操作相当于除以2。值得一提的是,虽然移位操作速度快,但可能使代码比较难于理解,所以最好加上一些注释。
本文转载于 http://andynjux.blogbus.com/logs/63161027.html
分享到:
相关推荐
主要介绍了分享几个提高Java性能的高效用法 ,需要的朋友可以参考下
因此,在 Java 6 中,使用 String.intern() 需要非常小心,避免使用这个方法 intern 任何无法控制的用户输入。 Java 7 中的字符串池 在 Java 7 中,Oracle 的工程师对字符串池的逻辑做了很大的改变,字符串池的...
在进行Java性能优化时,需要关注以下几个关键点: - **内存管理**:理解内存分配、垃圾收集机制,避免内存泄漏。 - **并发编程**:合理使用线程,避免过度竞争和死锁,利用并发库提升多核处理器利用率。 - **代码...
提高Java性能的方法主要包括以下几个方面: 1. 程序设计:良好的设计是性能优化的基础。采用合适的设计模式和方法可以有效利用资源,如内存、CPU、缓存和多线程,构建高性能、高可扩展性的系统。设计阶段就应考虑到...
在Java性能分析中,我们通常关注以下几个核心知识点: 1. **JVM内存模型**:Java虚拟机(JVM)使用堆、栈、方法区、元空间等不同内存区域。理解这些区域的工作原理对于识别内存泄漏和性能问题至关重要。例如,...
6. **避免字符串字面量的重复定义**:如果一个字符串在多处被使用,应将其定义为常量,以减少内存开销和提高代码可读性。例如: ```java public static final String MY_APP = "My Application"; private void ...
【如何提高Linux Java性能的分析】 Java应用程序在Linux平台上的性能优化是一个复杂而重要的主题,尤其是在高并发和大规模数据处理的场景下。Java线程堆分析是定位和解决性能问题的有效工具,它提供了关于应用程序...
以下是一些常用的Java性能调优命令及其用法和相关知识点。 1. jps命令用于列出所有的JVM实例。通过该命令,开发者可以快速查看本机上所有Java应用程序的进程ID。例如,使用`jps`可以列出本机所有的JVM实例。 2. ...
综上所述,Java性能测试与调优是一个涉及多个方面的复杂过程,需要考虑JVM配置、应用服务器设置、数据库性能监控以及代码层面的优化。通过细致地分析和调整,可以显著提高Java应用程序的性能和响应速度。文档中的...
Java性能优化是一个重要的主题,尤其是在开发大型企业级应用时,性能优化可以显著提升系统的响应速度和资源利用率。本文将深入探讨如何通过优化单例模式来提高Java代码的性能。 单例模式是一种常用的软件设计模式,...
本文将从几个关键方面探讨Java性能优化。 首先,理解性能的基本概念至关重要。性能通常包括五个方面:运算性能、内存分配效率、启动时间、程序可伸缩性和用户感知性能。不同的应用场景可能对这些方面有不同的侧重,...
在IT行业中,Java性能分析是优化应用程序的关键环节,它涉及到如何有效地使用系统资源,提高程序运行效率,并确保软件系统的稳定性。本主题将深入探讨Java性能分析的相关知识点,结合标签"源码"和"工具",我们将关注...
为了提高使用反射的应用程序的性能,可以采取以下策略: - **缓存反射对象**:如果相同的类或字段多次使用反射访问,则可以缓存其`Class`、`Field`或`Method`对象,避免每次重复查找和解析。 - **预热**:在应用程序...
本文将详细介绍10种Java性能优化策略,并重点解析文档中提到的几个关键点。 #### 二、hashCode() 方法优化 1. **背景**:`hashCode()` 方法在Java中用于快速查找对象。当对象存储在哈希表中时,例如`HashMap`,其...
在优化Java程序设计和编码以提高性能的过程中,有几个关键点需要注意。首先,我们要理解Java程序的性能瓶颈往往源自过度的对象创建、不必要的数据拷贝以及不恰当的数据结构使用。以下是几个常见的优化策略: 1. **...
PDF文档可能会涵盖以下几个关键知识点: 1. **JVM内存模型**:理解堆内存、栈内存、方法区以及垃圾回收机制,如何调整JVM参数以优化内存分配,避免内存泄漏和频繁的垃圾回收。 2. **代码优化**:编写高效代码,...
在Java性能调优领域,有以下几个核心知识点: 1. **JVM调优**:Java虚拟机(JVM)是Java程序运行的基础,其性能直接影响应用的响应速度和稳定性。书中会深入讲解JVM内存模型,包括堆内存、栈内存、方法区等,以及...
### JAVA程序性能优化 在Java开发中,程序性能优化是一个重要的环节,它直接影响到应用程序的运行效率、用户体验以及系统的整体稳定...通过对上述几个方面的理解和应用,可以有效地提高Java应用程序的性能和响应速度。
本文将详细介绍几款主流的Java性能分析工具,并进行对比分析,帮助开发者选择最适合自己的工具。 #### 1. VisualVM VisualVM是一款开源的工具,自JDK 6 Update 7起被默认包含在内。它能够提供CPU的使用情况、内存...
java调用本地dll的几种方法性能对比测试。 JNA消耗的总时间(ms):5406 bridj消耗的总时间(ms):984 JNI消耗的总时间(ms):47 包含c++源码和java源码,部署和使用方法。在win7和winxp下测试用过。 部分源码是...