目录
前言
有时,需要将int这样的基础数据类型转换为对象,所有的基础数据类型都有一个与之对应的类,称为包装类(或者包装器),这些包装类的有其名字如下:
基本类型 | 包装类 |
---|---|
int | Integer |
short | Short |
long | Long |
byte | Byte |
float | Float |
double | Double |
char | Character |
boolean | Boolean |
包装类同String类一样,是不可变的,一旦构造了包装类对象 ,就不能改变对应包装类中的属性。同时包装类是被final修饰的类,因此不能用来派生子类(不能被继承)。
java.lang包中的Integer类在对象中包装了一个基本数据类型,它包含一个int类型的字段。此外,Integer类中还包含了很多方法,用来处理int类型的数据,例如将int和String类型之间相互转化的方法等。
不只是int类型,long,short类型都可以封装成一个类,这些类都是Number的子类。
Integer的内部结构
Integer类型里面提供了一下四个常量
1、MAX_VALUE
表示int类型可取的最大值,即
![]()
2、MIN_VALUE
表示int类型可取的最小值,即
最大值,对应的十进制,八进制,和二进制,十六进制
最小值,对应的十进制,八进制,和二进制,十六进制
int与interger的内存比较
Integer对象会占用更多的内存。Integer是一个对象,需要存储对象的元数据。
但是int是一个原始类型的数据,所以占用的空间更少
下面通过几个实例来展示说明,加深理解。
实例1
Integer i = new Integer(100);
int j = 100;
System.out.print(i == j); //true
分析:两个通过new生成的变量实际上是两个Integer对象的引用,所以两个变量永远是不相等的(因为new生成的是两个对象,是对对象的引用,其内存地址不同)。
实例2
Integer i = new Integer(100);
int j = 100;
System.out.print(i == j); //true
分析:Integer变量和int变量比较时,只要两个变量的值是相等的,则结果为true.
因为包装类Integer和基本数据类型int比较时,Java会自动拆箱为int,然后进行比较,实际上就变为两个int变量的比较
实例3
Integer i = new Integer(100);
Integer j = 100;
System.out.print(i == j); //false
分析:非new生成的Integer变量和new Integer()生成的变量比较时,结果为false。
因为非new生成的Integer变量指向的是Java常量池中的对象,而new Integer()生成的变量指向堆中新建的对象的引用,它们在内存中的地址不同。
实例4
Integer i = 100;
Integer j = 100;
System.out.print(i == j); //true
分析:对于两个非new生成的Integer对象,进行比较时,如果两个变量的值在区间-128到127之间,则比较结果为true,如果两个变量的值不在此区间,则比较结果为false。
实例5
注意:如果值不在-128到127之间,这时结果就是false。
Integer i = 128;
Integer j = 128;
System.out.print(i == j); //false
Java对于-128到127之间的数会做缓存,当 Integer i = 127时,会将127进行缓存,下次再写Integer j = 127时,就会直接从缓存中取,不需要new了。
Integer i1=Integer.valueOf(127)
Integer.valueOf()这个方法底层代码:方法里创建了一个数组,里面创建好了Integer的对象,如果你传的参数为-128到127,那我就在数组里面去获取一个Integer的对象去给你返回,如果超出了-128到127的范围那我就给你返回一个新创建的Integer的对象
这么做的目的:因为-128到127这个范围的数经常被用到,那么如果每次都要创建新的对象,太浪费空间了