首页 > 代码库 > int与Integer的爱恨情仇
int与Integer的爱恨情仇
int作为java中元老级的数据类型,可谓无处不在,自从jdk5诞生了Integer,从此不在孤单。
为什么要设计Integer呢?它与int有什么区别?
一、Integer是int的包装类型,是引用类型,int是值类型。
衍生出来的特点就是:
(1)Integer比较时比较地址,int比较时比较值,Integer与int比较又如何呢?留个疑问,下面再论。
(2)以对象的属性存在时,Integer初始默认值为null,int为0;在方法作用域内,变量是要手动进行初始化滴,若只声明,在后面使用的时候编译器是通不过的。
二、出于数据转换的考虑
Integer提供了两种方法,parseInt和valueOf,看下面:
String s = "1"
int a = Integer.parseInt(s)
Integer b = Integer.valueOf(s)
Integer c = Integer.valueOf(1)
1)parseInt接收String类型的入参,返回int
2)valueOf接收String和int类型的入参,返回Integer
ps:当然,你这样写也是成立的:int d = Integer.valueOf(s),编译器进行了隐式拆箱,将Integer转化为了int。
三、比较
1、int与Integer
int a = 1;
Integer b = 1;
a==b为true,b先进性拆箱,与a比较的是值
2、 Integer与Integer
Integer a = new Integer(1)
Integer b = 1
Integer c = 1
a==b? false
解:a存在于内存堆中,b存在于常量池中,地址不同。任何new都会产生新的对象;Integer b = 1进行了隐式的装箱(调用了valueOf方法)
b==c? true
解:在内存中,会有一块叫做常量池的区域,专门存放b和c这种形式定义的对象,初始化时会先去常量池中寻找1,若已经存在,直接指向1,若不存在,生成对象1放入常量池。
再看这个:
Integer d = 128
Integer e = 128
d==e?false
为什么这个不适合上面的常量池说法了呢?原因在于常量池指定了数值范围:-128~127。
超过了这个范围,就会生成新的对象。
3、比较两个Integer的值
Integer a = new Integer(1)
Integer b = new Integer(2)
可以这样:a.intValue() == b.intValue() 或者 a.equals(b)
四、获取最大值和最小值如此简单
int a = Integer.MAX_VALUE; 2^31-1
int b = Integer.MIN_VALUE; -2^31
五、使用场景的限制
1)很多方法参数就只接收对象类型
2)泛型只支持对象类型
3)考虑到数据库设计中某些数值列可以为null,持久话对象中使用引用类型,可接收null值
关注老姜谈技术,微信号:helojava,或者扫描下面二维码。
每日一帖,技术鸡汤。
int与Integer的爱恨情仇