专栏首页cwl_Java性能优化-测试If-Else和if哪个性能更好

性能优化-测试If-Else和if哪个性能更好

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/weixin_42528266/article/details/103280680

代码示例
package com.cwl.po.judge;

/**
 * @program: cwl-performance-optimization
 * @description: 测试If-Else和if哪个性能更好
 * @author: ChenWenLong
 * @create: 2019-11-27 11:23
 **/
public class TestIfAndIfElse {

    // 结论 使用If 和 If-Else性能相同
    public static void main(String[] args) {
        System.out.println(testIf());// 8ms
        System.out.println(testSwitch());// 8ms
    }

    /**
     * 功能描述:
     * 〈测试switch性能〉
     *
     * @return : long
     * @params : []
     * @author : cwl
     * @date : 2019/11/27 11:24
     */
    private static long testSwitch() {
        long begin = System.currentTimeMillis();
        int a = 0;
        int b = 0;
        int c = 0;
        int d = 0;
        int e = 0;
        int f = 0;
        int g = 0;
        for (int i = 0; i < 100000000; i++) {
            if(i < 2000){
                a += i;
            }else if(2000 < i && i < 4000){
                b += i;
            }else if(4000 < i && i <6000){
                c += i;
            }else if(6000 < i && i < 8000){
                d += i;
            }else if(8000 < i && i < 10000){
                e += i;
            }else if(10000 < i && i < 12000){
                f += i;
            }else if(12000 < i && i < 14000){
                g += i;
            }
        }
        System.out.println(a+b+c+d+e+f+g);
        long end = System.currentTimeMillis();
        return end - begin;
    }

    /**
     * 功能描述:
     * 〈测试If的性能〉
     *
     * @return : long
     * @params : []
     * @author : cwl
     * @date : 2019/11/27 11:24
     */
    private static long testIf() {
        long begin = System.currentTimeMillis();
        int a = 0;
        int b = 0;
        int c = 0;
        int d = 0;
        int e = 0;
        int f = 0;
        int g = 0;
        for (int i = 0; i < 100000000; i++) {
            if(i < 2000){
                a += i;
            }
            if(2000 < i && i < 4000){
                b += i;
            }
            if(4000 < i && i <6000){
                c += i;
            }
            if(6000 < i && i < 8000){
                d += i;
            }
            if(8000 < i && i < 10000){
                e += i;
            }
            if(10000 < i && i < 12000){
                f += i;
            }
            if(12000 < i && i < 14000){
                g += i;
            }
        }
        System.out.println(a+b+c+d+e+f+g);
        long end = System.currentTimeMillis();
        return end - begin;
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • C++经典算法题-排序法 - 改良的选择排序

    选择排序法的概念简单,每次从未排序部份选一最小值,插入已排序部份的后端,其时间主要花费于在整个未排序部份寻找最小值,如果能让搜寻最小值的方式加 快,选择排序法的...

    cwl_java
  • C++-入门语法(三)

    cwl_java
  • 经典笔试题-JAVA实现快速排序算法

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 ...

    cwl_java
  • codevs 1213 解的个数

    1213 解的个数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知整数x...

    attack
  • 洛谷P3690 【模板】Link Cut Tree (LCT)

    attack
  • 批量升级python版本的shell

    1.准备一个文件放入所有需要升级的服务器IP:ansible_failed_ip.txt

    py3study
  • hdu1051

    @坤的
  • UITextView字数限制

    王大锤
  • ArrayList源码解析

    最近在整理数据结构和算法,发现java的源码很优秀。就学习一下, 这里做个记录。 我使用的是jdk

    若与
  • UITextView字数限制

    王大锤

扫码关注云+社区

领取腾讯云代金券