zoukankan      html  css  js  c++  java
  • java自动装箱(是否是误区)

    从JDK1.5开始,引入了自动装箱和自动拆箱的概念,实现了把基本数据类型转化为对象,以及把对象转化为基本数据类型,这给我们开发中提供了不少的便利,不过也存在一些使用的细节,如果使用不当,也可能造成相当严重的后果哦。

    首先来看下面一段代码:

    public static void main(String[] args) {
        Integer sum = 0;
        for (int i = 0; i <= 100; i++) {
            sum += i;
        }
        System.out.println(sum);
    }
    

    代 码很简单,只是对1到100内的数字进行求和,似乎一点问题也没有,不过当我们把100换成Integer.MAX_VALUE(2147483647) 时,似乎执行的时间有些久哦,废话,循环次数变多了,当然久了啊,似乎很有道理,真的是这样吗?我们再把Integer换成int,同时我们来计算一下时 间,代码如下:

    public static void main(String[] args) {
        System.out.println(time1());
        System.out.println(time2());
    }
    
    public static long time1() {
        Date date1 = new Date();
        int sum = 0;
        for (int i = 0; i < Integer.MAX_VALUE; i++) {
            sum += i;
        }
        return new Date().getTime() - date1.getTime();
    }
    
    public static long time2() {
        Date date1 = new Date();
        Integer sum = 0;
        for (int i = 0; i < Integer.MAX_VALUE; i++) {
            sum += i;
        }
        return new Date().getTime() - date1.getTime();
    }
    

    执行结果好可怕,使用int,耗费1859ms,使用Integer耗费20381ms,当然这只有随机一次执行的结果,使用Integer构造了大约 2147483648的实例,使JVM的压力骤然增大,效率自然差别很大。因此:我们要优先使用基本类型,而不是装箱基本类型,要当心无意识的自动装箱

  • 相关阅读:
    elasticsearch painless脚本评分
    elasticsearch relevance score相关性评分的计算
    java 多线程间通信(二)
    java 多线程间通信(一)
    java CountDownLatch、CyclicBarrier和 Semaphore用法
    java 深入剖析ThreadLocal
    java中String、StringBuffer、StringBuilder的区别
    Leetcode: LRU Cache
    Leetcode: Anagrams(颠倒字母而成的字)
    Leetcode: First Missing Positive
  • 原文地址:https://www.cnblogs.com/hexie/p/4975247.html
Copyright © 2011-2022 走看看