new Integer(1)和Integer.valueOf(1)的区别
2016-06-21 11:18
423 查看
java.lang包中的Integer类是我们比较常用的类,比如以下代码:
Integer a=new Integer(1)
Integer a=Integer.valueOf(1);
两个都是得到一个Integer对象,但是Integer.valueOf的效率高。为什么呢?因为Integer.valueOf用到了缓存机制。
其中Integer.valueOf方法代码如下:
public static Integer valueOf(int i) {
final int offset = 128;
if (i >= -128 && i <= 127) { // must cache
return IntegerCache.cache[i + offset];
}
return new Integer(i);
}
在这个类中使用到了一个辅助类IntegerCache,其中IntegerCache的源代码如下:
private static class IntegerCache {
private IntegerCache(){}
static final Integer cache[] = new Integer[-(-128) + 127 + 1];
static {
for(int i = 0; i < cache.length; i++)
cache[i] = new Integer(i - 128);
}
}
可以看到在IntegerCache中已经初始化了cache数组。所以,要注意的是,new Integer返回的永远是不同的对象,但是当整数范围在-128<i<=127时,Integer.valueOf返回的是同一个对象。
看下面代码:
Integer a=new Integer(1);
Integer b=new Integer(1);
//整数范围在-128到127之间,返回的是同一个对象
Integer c=Integer.valueOf(1);
Integer d=Integer.valueOf(1);
//返回的不是同一个对象
Integer e=Integer.valueOf(200);
Integer f=Integer.valueOf(200);
System.out.println(a==b);
System.out.println(c==d);
System.out.println(e==f);
程序运行的结果为:
false
true
false
Integer a=new Integer(1)
Integer a=Integer.valueOf(1);
两个都是得到一个Integer对象,但是Integer.valueOf的效率高。为什么呢?因为Integer.valueOf用到了缓存机制。
其中Integer.valueOf方法代码如下:
public static Integer valueOf(int i) {
final int offset = 128;
if (i >= -128 && i <= 127) { // must cache
return IntegerCache.cache[i + offset];
}
return new Integer(i);
}
在这个类中使用到了一个辅助类IntegerCache,其中IntegerCache的源代码如下:
private static class IntegerCache {
private IntegerCache(){}
static final Integer cache[] = new Integer[-(-128) + 127 + 1];
static {
for(int i = 0; i < cache.length; i++)
cache[i] = new Integer(i - 128);
}
}
可以看到在IntegerCache中已经初始化了cache数组。所以,要注意的是,new Integer返回的永远是不同的对象,但是当整数范围在-128<i<=127时,Integer.valueOf返回的是同一个对象。
看下面代码:
Integer a=new Integer(1);
Integer b=new Integer(1);
//整数范围在-128到127之间,返回的是同一个对象
Integer c=Integer.valueOf(1);
Integer d=Integer.valueOf(1);
//返回的不是同一个对象
Integer e=Integer.valueOf(200);
Integer f=Integer.valueOf(200);
System.out.println(a==b);
System.out.println(c==d);
System.out.println(e==f);
程序运行的结果为:
false
true
false
相关文章推荐
- GetChar缓存机制深入剖析
- 简介JavaScript中valueOf()方法的使用
- 全面解析JavaScript中的valueOf与toString方法(推荐)
- JavaScript函数中关于valueOf和toString的理解
- JS中令人发指的valueOf方法介绍
- Mysql错误1366 - Incorrect integer value解决方法
- JavaScript更改原始对象valueOf的方法
- javascript中tostring()和valueof()的用法及两者的区别
- Android使用缓存机制实现文件下载及异步请求图片加三级缓存
- Javascript中valueOf与toString区别浅析
- 浅谈Ajax的缓存机制
- Java中关于int和Integer的区别详解
- java中的Integer的toBinaryString()方法实例
- 浅析java中Integer传参方式的问题
- 关于TextView的setText()与Integer之间一个易犯的小错误 3ff8
- 数据类型转换
- 浏览器缓存机制
- Integer 比较遇到过的坑
- Java:int 和 Integer 的区别 (转载)
- Java Integer值的比较需注意