完成同样的功能,用不同的代码来实现,性能上可能会有比较大的差别,所以对于一些性能敏感的模块来说,对代码进行一定的优化还是很有必要的。今天就来说一下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. Python中struct.pack()和struct.unpack()

    https://blog.csdn.net/tjuyanming/article/details/79700601 https://www.cnblogs.com/yezl/p/5861787.htm ...

  2. maven(二)基于intellij idea搭建maven项目

    搭建步骤: 1.File -> New Module,进入创建项目窗口. 接着下一步,这里需要注在Properties中添加一个参数 archetypeCatalog=internal,不加这个 ...

  3. fs.watchFile

    [fs.watchFile] fs.watchFile(filename[, options], listener) Watch for changes on filename. The callba ...

  4. 搭建jsp渗透测试环境

    java运行环境下载地址:http://www.oracle.com/technetwork/java/javase/downloads/jre8-downloads-2133155.html fir ...

  5. SQLdeveloper同时显示多个表的窗口

  6. WDlinux 修改后台默认8080端口的方法

    修改8080端口正确方法 新版本: 方法一: apache sed -i 's/8080/8088/' /www/wdlinux/wdapache/conf/httpd.conf 然后记得修改防火墙i ...

  7. Django model 中的 class Meta 详解

    Django model 中的 class Meta 详解 通过一个内嵌类 "class Meta" 给你的 model 定义元数据, 类似下面这样: class Foo(mode ...

  8. Zabbix3.2下Template App Zabbix Server+Template OS Linux Item

    序号 Name Key 返回值 释义1 Agent ping agent.ping 1 就是ping一下2 Avaliable memory vm.memory.size[available] 563 ...

  9. python爬虫----scrapy框架简介和基础应用

    Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 其可以应用在数据挖掘,信息处理或存储历史数据等一系列的程序中.其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的, 也可以 ...

  10. Application的特点

    1.生命周期长.(内存泄漏) 2.单实例(一个进程就只有一个Application的实例对象) 3.onCreate的方法,可以认为一个应用程序的入口,做一些初始化的事情 4.不能自己new出 App ...