- Integer 与基本类型区别
- Ingeter是基本类型int的包装类,保存的是内存的引用
- Ingeter的初值为null
- Integer的赋值方式 Integer num = 10; 或者 Integer num = new Integer(10);
- int是java的基本类型,保存的是数据值
- int的初始值为0
- int的赋值方式 int num = 0;
- 遇到的问题
当Integer A 与 Integer B 比较值是否相等时遇到与预期结果不一致的情况
public static void main(String[] args)
{
Integer a = 1000, b = 1000;
System.out.println(a == b);
Integer c = 100, d = 100;
System.out.println(c == d);
}
返回结果为
false
true
- 结果分析
- 首先因为Integer是引用类型,保存的是内存的引用,c d返回true表明c d是指向同一个内存地址。
- 但是对于同样方式初始化和比较的a b两个值,结果却是false。
- 结合以上信息,猜测是Integer赋值的方法
- 基本数据类型的自动装箱(autoboxing)、拆箱(unboxing)
一般我们要创建一个类的对象实例的时候,我们会这样:
Class a = new Class(parameter);
当我们创建一个Integer对象时,却可以这样:
Integer i = 100; (注意:不是 int i = 100; )
通过反编译class文件,发现实际上执行上面那句代码的时候,系统为我们执行了:
Integer i = Integer.valueOf(100);
- 所以问题的关键在于Integer.valueOf方法
public static Integer valueOf(int i) {
assert IntegerCache.high >= 127;
if (i >= IntegerCache.low && i <= IntegerCache.high)
return IntegerCache.cache[i + (-IntegerCache.low)];
return new Integer(i);
}
private static class IntegerCache {
static final int low = -128;
static final int high;
static final Integer cache[];
·
·
·
}
由以上代码片段我们可以得出,java在给Integer自动装箱赋值时如果值在-128到127范围之内,则返回已经创建好的IntegerCache数据,如果不在范围内,则new一块新的内存空间保存数值。
- 扩展思考 Integer i = 200; 与 int j = 200; 相互比较呢?
Integer i = 200;
int j = 200;
System.out.println(i == j);
输出结果为: true
这里继续反编译class文件,看到实际编译后的代码为:
System.out.println(i.intValue() == j);
这里intValue() 其实就是Integer的自动拆箱操作 当Integer类型与基本数据类型int比较时,java会自动把Integer转为值的方式与基本类型int对比。
- 分析完以上代码之后思考一个问题,如果不采用java自动装箱的机制,而是new的方式给Integer赋值
Integer i = new Integer(20);
Integer j = new Integer(20);
System.out.println(i == j);
输出结果为: false
运行结果也证明new的方式赋值,一定会开辟新的内存空间。
- 扩展一: java中其他包装类型的缓存情况
Boolean:(全部缓存)
Byte:(全部缓存)
Character(<= 127缓存)
Short(-128 — 127缓存)
Long(-128 — 127缓存)
Float(没有缓存)
Doulbe(没有缓存)
- 扩展二: 数据库映射实体类为什么要用Integer类型
"int" in mybatis xml files is an alias of java.lang.Integer,
use _integer instead if you want to map a java int.
网友评论