Java 编程:如何提高性能?(简单总结篇)

开发者在编程中除了要有编程规范,还要注意性能,在 Java 编程中有什么提高性能的好办法呢?

本文转自国内 ITOM 行业领军企业 OneAPM Cloud Insight(一款能够优雅监控多种操作系统、数据库、中间件、云主机的解决方案)美女工程师陈永梅简书

开发者在编程中除了要有编程规范,还要注意性能哦,今天就工作中遇到的一些问题进行了一个简单总结,希望攻城狮来批评指正。

作为一个QA,从质量管理方面得到的认识:

  • 一行代码能解决的问题 尽量不要使用多行,代码行数越多 维护成本越高,出现缺陷的概率也就越多;
  • 一行代码编写可能只需要 30s,发现并优化一行代码产生的性能问题需要 72h,甚至更多。

不说了,下面就简单说下实际编程过程中性能相关的问题吧:

1、循环逻辑中减少创建对象次数

例如:

for(int i = 0;i < list.size; i ++) {
…
}

应替换为:

for(int i = 0,int len = list.size();i < len; i ++) {
…
}

2、关注循环结构是否存在多次访问网络、数据库等操作

原则:能够一次性查询完成的 尽量避免多次查询。

优化前:

优化后:

3、对象容错性差

原则:参数传递过程中不要直接转换使用 JSONObject 这种对象,如果取值不存在该方法会报异常导致程序中止,尽量转为 JavaBean 或 Map;否则应先判断取的值是否存在。最好以 JavaBean 封装接收参数,并对参数进行初步较验,不能将数据完整性交给前端处理。

如果使用 JSONObject 对象,应先进行存在判断if(json.contains(“xxx”))

4、对需要缓存的信息进行合理设计

原则:登录功能要分析哪些是跟用户密切相关的,如 session 信息,哪些是跟业务系统属性相关的,如系统配置资源信息。后者则应当进行缓存处理,避免每次登录都构建获取信息。

5、业务逻辑的执行顺序问题

原则:在进行逻辑判断的过程中,尽量使复杂操作延迟执行,不要提前执行;如登录操作,只有登录成功后才做相关资源加载、查询操作;

如示例:静态资源应尽量后置,建议大家在业务逻辑梳理时先否定再肯定,也就是先列不满足业务的条件。

优化前:

优化后:

6、Try…catch 相对消耗性能比较严重,尽量减少使用频率,使用中尽量扩大作用范围,禁止出现在循环等操作中。

7、创建类似数组等可以设定大小的对象,应尽可能指定大小,最大限度减少内存空间的浪费。

8、HashMap 的读取遍历使用 entry,而不是先取 key 集合,再取值。

9、在方法中创建的对象最好在使用完毕后将引用指向 null,利于 GC 垃圾回收。

10、数组复制使用 system.arraycopy(),减少使用创建新数组赋值的方法。

11、方法大小不要超过80行,方法栈太深容易导致内存溢出;尽量不要出现功能太少的类,类的维护也需要性能开销。

12、创建复杂对象应使用clone方法,减少构造方法调用的开销。

13、待续...

时间: 2024-10-29 12:17:30

Java 编程:如何提高性能?(简单总结篇)的相关文章

Java编程解析节省内存效率高的方法

原文:http://developer.51cto.com/art/201104/255104.htm 很多人都说"Java完了,只等着衰亡吧!",为什么呢?最简单的的例子就是Java做的系统时非常占内存!一听到这样的话,一定会有不少人站出来为Java辩护,并举出一堆的性能测试报告来证明这一点.其实从理论上来讲Java做的系统并不比其他语言开发出来的系统更占用内存,那么为什么却有这么多理由来证明它确实占内存呢?两个字,陋习(编程习惯). Java编程解析节省内存效率高的方法: 1.别用

Java性能优化通用篇

性能|优化 一.通用篇 "通用篇"讨论的问题适合于大多数Java应用. 1.1 不用new关键词创建类的实例 用new关键词创建类的实例时,构造函数链中的所有构造函数都会被自动调用.但如果一个对象实现了Cloneable接口,我们可以调用它的clone()方法.clone()方法不会调用任何类构造函数. 在使用设计模式(Design Pattern)的场合,如果用Factory模式创建对象,则改用clone()方法创建新的对象实例非常简单.例如,下面是Factory模式的一个典型实现:

Java编程性能优化技巧有哪些

1.尽量在合适的场合使用单例 使用单例可以减轻加载的负担,缩短加载的时间,提高加载的效率,但并不是所有地方都适用于单例,简单来说,单例主要适用于以下三个方面: 第一,控制资源的使用,通过线程同步来控制资源的并发访问: 第二,控制实例的产生,以达到节约资源的目的: 第三,控制数据共享,在不建立直接关联的条件下,让多个不相关的进程或线程之间实现通信. 2.尽量避免随意使用静态变量 要知道,当某个对象被定义为static变量所引用,那么GC通常是不会回收这个对象所占有的内存,如: 此时静态变量b的生命

两道相似的简单Java编程题,关于文件

问题描述 两道相似的简单Java编程题,关于文件 在A文件夹里有2000个文件,分别是A0.txt,A1.txt,A2.txt,--一直到A1999.txt, 一.我们从中随机选出200个文件复制到B文件夹中: 二.我们系统抽样选出200个文件复制到C文件夹中(比如选择A2.txt,A12.txt,A22.txt,依次加10到A1992.txt). 求大神帮忙!!! 解决方案 我的思路是这样的:首先对于可以用随机函数产生所选的文件之后就是对于随机到的每个文件分别进行复制 对于下面的系统抽样,我不

简单了解Java编程中对异常处理的运用_java

Java异常是一个描述在代码段中发生的异常(也就是出错)情况的对象.当异常情况发生,一个代表该异常的对象被创建并且在导致该错误的方法中被抛出(throw).该方法可以选择自己处理异常或传递该异常.两种情况下,该异常被捕获(caught)并处理.异常可能是由Java运行时系统产生,或者是由你的手工代码产生.被Java抛出的异常与违反语言规范或超出Java执行环境限制的基本错误有关.手工编码产生的异常基本上用于报告方法调用程序的出错状况. Java异常处理通过5个关键字控制:try.catch.th

简单介绍Java编程中的线程池_java

从 Java 5 开始,Java 提供了自己的线程池.线程池就是一个线程的容器,每次只执行额定数量的线程. java.util.concurrent.ThreadPoolExecutor 就是这样的线程池.它很灵活,但使用起来也比较复杂,本文就对其做一个介绍. 首先是构造函数.以最简单的构造函数为例: public ThreadPoolExecutor( int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit uni

编程-约瑟夫环问题用java怎么解决,有简单点的方法吗

问题描述 约瑟夫环问题用java怎么解决,有简单点的方法吗 一组人(n)个,围成一圈,从某人开始数到滴三个的人出列,在接着从下一个人开始数,最终输出最终出列的人(约瑟夫环是一个数学的应用问题:已知n个人(以编号1,2,3,...,n)分别表示)围坐在一张圆桌周围.从编号k的人开始报数,数到m的那个人出列:他的下一个人又从1开始报数,数到m的那个人又出列:依此规律重复下去,知道圆桌周围的人全都出列. 解决方案 import java.util.Scanner; public class count

java多线程提高性能写法

为了提高性能,不一定要锁定this,例如,SharedResource有两个独立变化的变量: public class SharedResouce {     private int a = 0;     private int b = 0;     public synchronized void setA(int a) { this.a = a; }     public synchronized void setB(int b) { this.b = b; } } 若同步整个方法,则set

面向GC的Java编程

该文章来自于阿里巴巴技术协会(ATA)精选文章. Java程序员在编码过程中通常不需要考虑内存问题,JVM经过高度优化的GC机制大部分情况下都能够很好地处理堆(Heap)的清理问题.以至于许多Java程序员认为,我只需要关心何时创建对象,而回收对象,就交给GC来做吧!甚至有人说,如果在编程过程中频繁考虑内存问题,是一种退化,这些事情应该交给编译器,交给虚拟机来解决. 这话其实也没有太大问题,的确,大部分场景下关心内存.GC的问题,显得有点"杞人忧天"了,高老爷说过: 过早优化是万恶之源