- 浏览: 406991 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (268)
- java (22)
- Acegi (8)
- Ajax (17)
- Annotation (3)
- Ant (3)
- JBOSS (6)
- Xdoclet (1)
- CSS (20)
- Data Warehouse (11)
- DB2 (3)
- DOM (1)
- dos (2)
- JMF (1)
- JMS (5)
- J2EE (17)
- Hibernate (7)
- struts (10)
- CORBA (1)
- 职业 (2)
- JSF (1)
- JSTL (8)
- 其它 (1)
- Log4j (7)
- svg (7)
- quartz (3)
- web2.0 (2)
- velocity (2)
- apache commons (1)
- js (9)
- html (4)
- sql (3)
- linux (4)
- dwr (14)
- spring (5)
- GWT (7)
- portlet (4)
- 软件工程 (10)
- actionscript (1)
- 测试 (1)
- tomcat (3)
- flash (0)
- 线程 (1)
- mysql (6)
- flex (1)
- oracle (7)
- crystalreport (4)
- itext (4)
- memcache (2)
- linux 监控 (2)
- mongodb (1)
- Kafka (5)
- 网络 (2)
- 分布式计算 (2)
最新评论
-
chenyongxin:
mark
JBoss 4.0.2集群基本知识及配置方法指南 -
softor:
我找到了,下载吧:http://ishare.iask.sin ...
jad是最简单的class反编译为java文件的小工具 (转载) -
softor:
求下载
dodo@lovehang.com
jad是最简单的class反编译为java文件的小工具 (转载) -
juedui0769:
不错!
请问: 如何在 将 log4j.appender ...
Tomcat 日志 配置 (转载) -
spp_1987:
// 建立一个上传文件的输出流
...
Struts上传多个及N个文件的例子
Java语言习惯用语
1.循环
■ 在重要的循环里,消除循环终止判断时的方法调用。。。
例如:将...
Java代码
1. for(int i=0; i<collection.size();i++){
2. ...
3. }
for(int i=0; i<collection.size();i++){
...
}
替换为…
Java代码
1. for(int i=0; n=collection.size();i<n;i++){
2. ...
3. }
for(int i=0; n=collection.size();i<n;i++){
...
}
■ 通常,把与循环index不相关的移到循环的外面
Java代码
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;
}
应该该成:
Java代码
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.异常
■ 异常只用于单个真正的错误条件
抛出一个异常和执行一个catch代码块花费是很高的(主要由于当创建一个异常时要获得线程栈的一个快照)
只当条件真的异常时才抛出一个异常
■ 抛出异常首先要创建一个新的对象。
Throwable接口的构造函数调用名为fillInStackTrace()的本地(Native)方法,fillInStackTrace()方法检查堆栈,收集调用跟踪信息。
只要有异常被抛出,VM就必须调整调用堆栈,因为在处理过程中创建了一个新的对象。
异常只能用于错误处理,不应该用来控制程序流程。
■ 使编译器和运行时最优化,将几个方法调用放在一个try/catch块中,而不是为每个方法调用实现几个try/catch块
Java代码
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
}
应该写为:
Java代码
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模式的一个典型实现:
Java代码
1. public static Credit getNewCredit() {
2. return new Credit();
3. }
public static Credit getNewCredit() {
return new Credit();
}
优化后:
Java代码
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.乘法和除法
■考虑下面的代码:
Java代码
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; }
优化后:
Java代码
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。值得一提的是,虽然移位操作速度快,但可能使代码比较难于理解,所以最好加上一些注释。
1.循环
■ 在重要的循环里,消除循环终止判断时的方法调用。。。
例如:将...
Java代码
1. for(int i=0; i<collection.size();i++){
2. ...
3. }
for(int i=0; i<collection.size();i++){
...
}
替换为…
Java代码
1. for(int i=0; n=collection.size();i<n;i++){
2. ...
3. }
for(int i=0; n=collection.size();i<n;i++){
...
}
■ 通常,把与循环index不相关的移到循环的外面
Java代码
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;
}
应该该成:
Java代码
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.异常
■ 异常只用于单个真正的错误条件
抛出一个异常和执行一个catch代码块花费是很高的(主要由于当创建一个异常时要获得线程栈的一个快照)
只当条件真的异常时才抛出一个异常
■ 抛出异常首先要创建一个新的对象。
Throwable接口的构造函数调用名为fillInStackTrace()的本地(Native)方法,fillInStackTrace()方法检查堆栈,收集调用跟踪信息。
只要有异常被抛出,VM就必须调整调用堆栈,因为在处理过程中创建了一个新的对象。
异常只能用于错误处理,不应该用来控制程序流程。
■ 使编译器和运行时最优化,将几个方法调用放在一个try/catch块中,而不是为每个方法调用实现几个try/catch块
Java代码
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
}
应该写为:
Java代码
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模式的一个典型实现:
Java代码
1. public static Credit getNewCredit() {
2. return new Credit();
3. }
public static Credit getNewCredit() {
return new Credit();
}
优化后:
Java代码
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.乘法和除法
■考虑下面的代码:
Java代码
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; }
优化后:
Java代码
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。值得一提的是,虽然移位操作速度快,但可能使代码比较难于理解,所以最好加上一些注释。
发表评论
-
微信支付或者支付宝支付验签太慢
2017-02-08 17:13 1260调用微信支付或者支付宝验签的时候会很慢,发现程序没有问题, ... -
ReentrantLock 源码分析(三)
2015-03-09 18:14 0这个章节还是分析 AbstractQueuedSynchr ... -
ReentrantLock 源码分析(二)
2015-03-09 18:04 515关于 Unsafe 的一些知识 A collecti ... -
线上事故分析
2015-03-03 14:10 1200事故现象 线上 ... -
memcache 调优
2015-03-03 11:50 709旧版测试结果 1, ... -
memcache 监控
2015-03-03 11:40 4251, 附件世php的监控文件,需要有php的运行环境 2 ... -
ReentrantLock 源码分析(一)
2015-03-09 17:24 661JDK 1.7.55 1, ReentrantLock ... -
解决html导出excel时数字被改成科学计数法的问题
2008-12-24 13:41 4124【适用范围】IE,JSP 【问题描述和定位】业务需要把一个h ... -
JDBC Hibernate 连接数据库连接字符串大全
2008-10-22 16:48 1131# Application configuration pro ... -
连接各种数据库的连接字符串(java)
2008-10-22 16:46 11881. MySQL(http://www.mysql.com)m ... -
jsp 乱码
2008-10-09 17:46 1169jsp中文显示乱码解决方案2006-12-27 22:56 ... -
JSP页面跳转的方法总结
2008-09-12 17:16 87961. response.sendRedirct(" ... -
jad是最简单的class反编译为java文件的小工具 (转载)
2008-06-24 15:44 7038jad是最简单的class反编译为java文件的小工具. 现 ... -
jspSmartUpload上传下载全攻略
2008-05-22 21:33 654一、安装篇 jspSmar ... -
JAVA数据库连接大全{经典} 转载
2008-05-12 14:51 1010Java数据库连接(JDBC)由一组用 Java 编程语言编写 ... -
用java实现断点续传(HTTP)
2007-10-28 12:23 994(一)断点续传的原理 其实断点续传的原理很简单,就是在Htt ... -
六大代码问题检验你的Java知识
2007-10-28 12:20 739六大代码问题检验你的Java知识 你觉得自己是一个Java ... -
J2SE(TM) 5.0专题 之 语言特性
2007-10-28 12:14 775J2SE(TM) 5.0专题 之 语言特性 [准备工作] ... -
AJAX+JSP实现基于WEB的文件上传的进度控制
2007-10-28 12:07 25641.引言 2.实现代码 2.1.服务器端代码 2.1.1 ... -
JAR文件包及jar命令详解
2007-10-28 11:59 1055常常在网上看到有人询问:如何把 java 程序编译成 .exe ...
相关推荐
主要介绍了分享几个提高Java性能的高效用法 ,需要的朋友可以参考下
在进行Java性能优化时,需要关注以下几个关键点: - **内存管理**:理解内存分配、垃圾收集机制,避免内存泄漏。 - **并发编程**:合理使用线程,避免过度竞争和死锁,利用并发库提升多核处理器利用率。 - **代码...
在Java性能分析中,我们通常关注以下几个核心知识点: 1. **JVM内存模型**:Java虚拟机(JVM)使用堆、栈、方法区、元空间等不同内存区域。理解这些区域的工作原理对于识别内存泄漏和性能问题至关重要。例如,...
以下是一些常用的Java性能调优命令及其用法和相关知识点。 1. jps命令用于列出所有的JVM实例。通过该命令,开发者可以快速查看本机上所有Java应用程序的进程ID。例如,使用`jps`可以列出本机所有的JVM实例。 2. ...
常见的Java性能分析工具有JProfiler、VisualVM、YourKit Java Profiler等。这些工具提供了深入的性能指标,如CPU使用率、内存分配、线程状态等,帮助开发者诊断和优化代码。 例如,JProfiler提供了丰富的可视化界面...
综上所述,Java性能测试与调优是一个涉及多个方面的复杂过程,需要考虑JVM配置、应用服务器设置、数据库性能监控以及代码层面的优化。通过细致地分析和调整,可以显著提高Java应用程序的性能和响应速度。文档中的...
Java反射机制是Java编程语言中一个强大的特性,它允许程序在运行时动态地访问、检测和修改类、接口、字段和方法等对象。然而,反射操作通常会引入额外的开销,这在性能敏感的应用场景下可能成为一个瓶颈。本文将深入...
在IT行业中,Java性能分析是优化应用程序的关键环节,它涉及到如何有效地使用系统资源,提高程序运行效率,并确保软件系统的稳定性。本主题将深入探讨Java性能分析的相关知识点,结合标签"源码"和"工具",我们将关注...
本文将从几个关键方面探讨Java性能优化。 首先,理解性能的基本概念至关重要。性能通常包括五个方面:运算性能、内存分配效率、启动时间、程序可伸缩性和用户感知性能。不同的应用场景可能对这些方面有不同的侧重,...
在Java性能调优领域,有以下几个核心知识点: 1. **JVM调优**:Java虚拟机(JVM)是Java程序运行的基础,其性能直接影响应用的响应速度和稳定性。书中会深入讲解JVM内存模型,包括堆内存、栈内存、方法区等,以及...
PDF文档可能会涵盖以下几个关键知识点: 1. **JVM内存模型**:理解堆内存、栈内存、方法区以及垃圾回收机制,如何调整JVM参数以优化内存分配,避免内存泄漏和频繁的垃圾回收。 2. **代码优化**:编写高效代码,...
本文将详细介绍10种Java性能优化策略,并重点解析文档中提到的几个关键点。 #### 二、hashCode() 方法优化 1. **背景**:`hashCode()` 方法在Java中用于快速查找对象。当对象存储在哈希表中时,例如`HashMap`,其...
### JAVA程序性能优化 在Java开发中,程序性能优化是一个重要的环节,它直接影响到应用程序的运行效率、用户体验以及系统的整体稳定...通过对上述几个方面的理解和应用,可以有效地提高Java应用程序的性能和响应速度。
因此,在 Java 6 中,使用 String.intern() 需要非常小心,避免使用这个方法 intern 任何无法控制的用户输入。 Java 7 中的字符串池 在 Java 7 中,Oracle 的工程师对字符串池的逻辑做了很大的改变,字符串池的...
java调用本地dll的几种方法性能对比测试。 JNA消耗的总时间(ms):5406 bridj消耗的总时间(ms):984 JNI消耗的总时间(ms):47 包含c++源码和java源码,部署和使用方法。在win7和winxp下测试用过。 部分源码是...
【如何提高Linux Java性能的分析】 Java应用程序在Linux平台上的性能优化是一个复杂而重要的主题,尤其是在高并发和大规模数据处理的场景下。Java线程堆分析是定位和解决性能问题的有效工具,它提供了关于应用程序...
本文将详细介绍几款主流的Java性能分析工具,并进行对比分析,帮助开发者选择最适合自己的工具。 #### 1. VisualVM VisualVM是一款开源的工具,自JDK 6 Update 7起被默认包含在内。它能够提供CPU的使用情况、内存...
Java内存模型主要包括以下几个部分: - **主内存**(Main Memory):所有线程共享的内存区域,存放着各个对象的实例数据。 - **工作内存**(Working Memory):每个线程拥有的私有内存空间,用于存放线程正在处理的...
2. 学习如何使用HP-UX提供的工具和命令进行Java性能调优。 3. 掌握如何配置Java支持,包括线程管理、文件打开限制、超时设置。 4. 掌握使用HPjconfig和HPjmeter等HP-UX专用工具进行系统参数调整和性能瓶颈检测。 5. ...
这样做有几个好处: 1. **防止方法覆盖**:确保类的方法不被子类覆盖,增强程序的稳定性。 2. **提高性能**:编译器可以内联`final`方法,从而提高程序执行速度。 #### 五、使用局部变量 局部变量存储在栈中,其...