Integer valueOf(1) & new Integer(1) 你造吗

来源:互联网 发布:淘宝网页版登陆首页 编辑:程序博客网 时间:2024/06/05 09:21

                                                                                 Integer valueOf(1) & new Integer(1) 你造吗

Integer a=new Integer(1)

Integer a=Integer.valueOf(1);

两个都是得到一个Integer对象,但是Integer.valueOf的效率高。为什么呢?因为Integer.valueOf用到了缓存。看看Integer.valueOf的代码:

Java代码  收藏代码
  1.    public static Integer valueOf(int i) {  
  2.     final int offset = 128;  
  3.     if (i >= -128 && i <= 127) { // must cache  
  4.         return IntegerCache.cache[i + offset];  
  5.     }  
  6.         return new Integer(i);  
  7.     }

 当传入的整数i:-128<i<=127时,从缓存里取出整数对应的Integer对象,否则创建一个Integer对象。基本上平时的程序中,这个范围的整数是最常用的。


  IntegerCache是什么?看看源码

Java代码  收藏代码
  1.    private static class IntegerCache {  //注意是静态的
  2.     private IntegerCache(){}  
  3.   
  4.     static final Integer cache[] = new Integer[-(-128) + 127 + 1];   //注意是静态的
  5.   
  6.     static {   //注意是静态的
  7.         for(int i = 0; i < cache.length; i++)  
  8.         cache[i] = new Integer(i - 128);  
  9.     }  
  10.     }

 可见,IntegerCache预先创建了这些Integer对象。


所以,要注意的是,new Integer返回的永远是不同的对象,但是当整数范围在-128<i<=127时,Integer.valueOf返回的是同一个对象。看看下面代码:

Java代码  收藏代码
  1.         Integer a=new Integer(1);  
  2.         Integer b=new Integer(1);  
  3.          
  4.         //整数范围在-128到127之间,返回的是同一个对象  
  5.         Integer c=Integer.valueOf(1);  
  6.         Integer d=Integer.valueOf(1);  
  7.          
  8.         //返回的不是同一个对象  
  9.         Integer e=Integer.valueOf(200);  
  10.         Integer f=Integer.valueOf(200);  
  11.          
  12.         System.out.println(a==b);  
  13.         System.out.println(c==d);  
  14.         System.out.println(e==f);  

输出为:

false
true
false


结论:不看不知道,一看吓一跳了,源码的力量好强大。

0 0
原创粉丝点击