Java 无意识自动装箱严重消耗性能

Java 无意识自动装箱严重消耗性能。

根据《effective java》书中所写,我测试了以下的简单例子。

package com.mwq.number;

public class Test {

    public static void main(String[] args) {
        long time1 = System.currentTimeMillis();

        long sum = 0L;
        for (int i = 0; i < Integer.MAX_VALUE / 2; i++) {
            sum += i;
        }

        System.out.println(sum);

        long time2 = System.currentTimeMillis();

        System.out.println(time2 - time1);

        Long sum1 = 0L;
        for (int i = 0; i < Integer.MAX_VALUE / 2; i++) {
            sum1 += i;
        }

        System.out.println(sum);

        long time3 = System.currentTimeMillis();

        System.out.println(time3 - time2);
    }

}

例子很简单,看看Long和long在+i的时候到底有多大的区别,花费的时间是如何的。

看结果,由于我电脑计算0到Integer.MAX_VALUE 的运算速度太慢,所以就只取了一半的量。

576460750692810753
1903
576460750692810753
10939

差了一个数量级!!!!!!!!!

sum在被声明为Long而不是long的时候,就会创造N(具体多少个N,我还真不知道,书中说的是2的31次方,显然我的不是)多个Long实例!

总结:自动装箱发生的太频繁的话,严重消耗性能。

你可能感兴趣的:(java,性能,自动装箱)