完成同样的功能,用不同的代码来实现,性能上可能会有比较大的差别,所以对于一些性能敏感的模块来说,对代码进行一定的优化还是很有必要的。今天就来说一下java代码优化的事情,今天主要聊一下对于for(while等同理)循环的优化。

作为三大结构之一的循环,在我们编写代码的时候会经常用到。循环结构让我们操作数组、集合和其他一些有规律的事物变得更加的方便,但是如果我们在实际开发当中运用不合理,可能会给程序的性能带来很大的影响。所以我们还是需要掌握一些技巧来优化我们的代码的。

嵌套循环

  1. stratTime = System.nanoTime();
  2. for (int i = 0; i < 10000000; i++) {
  3. for (int j = 0; j < 10; j++) {
  4. }
  5. }
  6. endTime = System.nanoTime();
  7. System.out.println("外大内小耗时:"+ (endTime - stratTime));

应改为:

  1. stratTime = System.nanoTime();
  2. for (int i = 0; i <10 ; i++) {
  3. for (int j = 0; j < 10000000; j++) {
  4. }
  5. }
  6. endTime = System.nanoTime();
  7. System.out.println("外小内大耗时:"+(endTime - stratTime));

两者耗时对比:

[plain] view plaincopy

  1. 外大内小耗时:200192114
  2. 外小内大耗时:97995997

由以上对比可知,优化后性能提升了一倍,嵌套循环应该遵循“外小内大”的原则,这就好比你复制很多个小文件和复制几个大文件的区别。

提取与循环无关的表达式

  1. stratTime = System.nanoTime();
  2. for (int i = 0; i < 10000000; i++) {
  3. i=i*a*b;
  4. }
  5. endTime = System.nanoTime();
  6. System.out.println("未提取耗时:"+(endTime - stratTime));

应改为:

  1. stratTime = System.nanoTime();
  2. c = a*b;
  3. for (int i = 0; i < 10000000; i++) {
  4. i=i*c;
  5. }
  6. endTime = System.nanoTime();
  7. System.out.println("已提取耗时:"+(endTime - stratTime));

两者耗时对比:

[plain] view plaincopy

  1. 未提取耗时:45973050
  2. 已提取耗时:1955

代码中a+b与我们的循环无关,所以应该把它放到外面,避免重复计算,可以看出,优化后性能提升了好几个数量级,这些是不容忽视的。

消除循环终止判断时的方法调用

  1. stratTime = System.nanoTime();
  2. for (int i = 0; i < list.size(); i++) {
  3. }
  4. endTime = System.nanoTime();
  5. System.out.println("未优化list耗时:"+(endTime - stratTime));

应改为:

  1. stratTime = System.nanoTime();
  2. int size = list.size();
  3. for (int i = 0; i < size; i++) {
  4. }
  5. endTime = System.nanoTime();
  6. System.out.println("优化list耗时:"+(endTime - stratTime));

两者耗时对比:

[plain] view plaincopy

  1. 未优化list耗时:27375
  2. 优化list耗时:2444

list.size()每次循环都会被执行一次,这无疑会影响程序的性能,所以应该将其放到循环外面,用一个变量来代替,优化前后的对比也很明显。

异常捕获

  1. stratTime = System.nanoTime();
  2. for (int i = 0; i < 10000000; i++) {
  3. try {
  4. } catch (Exception e) {
  5. }
  6. }
  7. endTime = System.nanoTime();
  8. System.out.println("在内部捕获异常耗时:"+(endTime - stratTime));

应改为:

  1. stratTime = System.nanoTime();
  2. try {
  3. for (int i = 0; i < 10000000; i++) {
  4. }
  5. } catch (Exception e) {
  6. }
  7. endTime = System.nanoTime();
  8. System.out.println("在外部捕获异常耗时:"+(endTime - stratTime));

两者耗时对比:

[plain] view plaincopy

  1. 在内部捕获异常耗时:12150142
  2. 在外部捕获异常耗时:1955

大家都知道,捕获异常是很耗资源的,所以不要讲try catch放到循环内部,优化后同样有好几个数量级的提升。

java性能优化之for循环的更多相关文章

  1. 菜鸟要做架构师(二)——java性能优化之for循环

    完成同样的功能,用不同的代码来实现,性能上可能会有比较大的差别,所以对于一些性能敏感的模块来说,对代码进行一定的优化还是很有必要的.今天就来说一下java代码优化的事情,今天主要聊一下对于for(wh ...

  2. 推荐:Java性能优化系列集锦

    Java性能问题一直困扰着广大程序员,由于平台复杂性,要定位问题,找出其根源确实很难.随着10多年Java平台的改进以及新出现的多核多处理器,Java软件的性能和扩展性已经今非昔比了.现代JVM持续演 ...

  3. Java 性能优化手册 — 提高 Java 代码性能的各种技巧

    转载: Java 性能优化手册 - 提高 Java 代码性能的各种技巧 Java 6,7,8 中的 String.intern - 字符串池 这篇文章将要讨论 Java 6 中是如何实现 String ...

  4. 【转】10种简单的Java性能优化

    10种简单的Java性能优化 2015/06/23 | 分类: 基础技术 | 14 条评论 | 标签: 性能优化 分享到: 本文由 ImportNew - 一直在路上 翻译自 jaxenter.欢迎加 ...

  5. JAVA性能优化的五种方式

    一,JAVA性能优化之设计优化 设计优化处于性能优化手段的上层.它往往须要在软件开发之前进行.在软件开发之前,系统架构师应该就评估系统可能存在的各种潜在问题和技术难点,并给出合理的设计方案,因为软件设 ...

  6. 44个Java性能优化

    44个Java性能优化 首先,代码优化的目标是: 减小代码的体积 提高代码运行效率 代码优化细节 1 .尽量指定类.方法的final修饰符 ​ 带有final修饰符的类是不可派生的.在Java核心AP ...

  7. Java 性能优化的55个细节(珍藏版)

    在Java程序中,性能问题的大部分原因并不在于Java语言,而是程序本身.养成良好的编码习惯非常重要,能够显著地提升程序性能. 1.尽量在合适的场合使用单例 使用单例可以减轻加载的负担,缩短加载的时间 ...

  8. Java性能优化,操作系统内核性能调优,JYM优化,Tomcat调优

    文章目录 Java性能优化 尽量在合适的场合使用单例 尽量避免随意使用静态变量 尽量避免过多过常地创建Java对象 尽量使用final修饰符 尽量使用局部变量 尽量处理好包装类型和基本类型两者的使用场 ...

  9. 【Java 调优】Java性能优化

    Java性能优化的50个细节(珍藏版) 1. 尽量在合适的场合使用单例 使用单例可以减轻加载的负担,缩短加载的时间,提高加载的效率,但并不是所有地方都适用于单例,简单来说,单例主要适用于以下三个方面: ...

随机推荐

  1. jenkin、SVN、archery集成openLDAP

    jenkins: 1.下载.安装插件 LDAP .Matrix Authorization Strategy 2. 系统管理 —> 全局安全配置 点击 启用安全,并且选择 LDAP 认证,这里有 ...

  2. Ant 之 Task

    Ant提供了大量的核心task和可选task,除此之外,Ant还允许用户定义自己的task,这大大扩展了Ant的功能.本书由于篇幅关系,所以不可能详细介绍Ant所有的核心task和可选task,本书将 ...

  3. 缩点+最小路径覆盖 hdu 3861

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3861 题意:输入t,表示t个样例.接下来每个样例第一行有两个数n,m表示点数和有向边的数量,接下来输入 ...

  4. TOJ1698/POJ3264Balanced Lineup (线段树 or RMQ-ST)

    传送门:http://acm.tzc.edu.cn/acmhome/problemdetail.do?&method=showdetail&id=1698 时间限制(普通/Java): ...

  5. 浅谈CSRF

    CSRF是什么? (Cross Site Request Forgery, 跨站域请求伪造)是一种网络的攻击方式,它在 2007 年曾被列为互联网 20 大安全隐患之一,也被称为“One Click ...

  6. TZOJ 2725 See you~(二维树状数组单点更新区间查询)

    描述 Now I am leaving hust acm. In the past two and half years, I learned so many knowledge about Algo ...

  7. js常用的数组,,字符串,,Math..正则方法

    数组 slice[start,end] 返回从原数组中指定开始下标到结束下标之间的项目组成新数组(不会影响原数组) splice() 1.删除功能:2个参数 , 起始位置 , 删除的项目 2.插入功能 ...

  8. ADT和DS

    Abstract Data Type vs. Data Structrue 抽象数据类型=数据模型+定义在该模型上的一组操作.  interface 数据结构=基于某种特定语言,实现ADT的一整套算法 ...

  9. golang 常用的正则查找与替换

    package main; import ( "regexp" "fmt" "strings" ) func main() { //1.过正 ...

  10. jQuery 向另一个页面传参,同时跳转到该页面

    为了使参数能够传递到另外一个页面,使用ajax的跳转方式 $.ajax({ type: "POST", url:"/admin/sysjgl/sysjck/sjcs&qu ...