结果
结果剖析:
1.i和i0均是普通类型(int)的变量,以是数据直接存储在栈中,而栈有一个很主要的特性:栈中的数据可以共享。当我们定义了int i = 40;,再定义int i0 = 40;这时候会自动检讨栈中是否有40这个数据,如果有,i0会直接指向i的40,不会再添加一个新的40。
2.i1和i2均是引用类型,在栈中存储指针,由于Integer是包装类。由于Integer包装类实现了常量池技能,因此i1、i2的40均是从常量池中获取的,均指向同一个地址,因此i1=12。
3.很明显这是一个加法运算,Java的数学运算都是在栈中进行的,Java会自动对i1、i2进行拆箱操作转化成整型,因此i1在数值上即是i2+i3。
4.i4和i5均是引用类型,在栈中存储指针,由于Integer是包装类。但是由于他们各自都是new出来的,因此不再从常量池探求数据,而是从堆中各自new一个工具,然后各自保存指向工具的指针,以是i4和i5不相等,由于他们所存指针不同,所指向工具不同。
5.这也是一个加法运算,和3同理。
6.d1和d2均是引用类型,在栈中存储指针,由于Double是包装类。但Double包装类没有实现常量池技能,因此Doubled1=1.0;相称于Double d1=new Double(1.0);,是从堆new一个工具,d2同理。因此d1和d2存放的指针不同,指向的工具不同,以是不相等。
小结:
1.以上提到的几种基本类型包装类均实现了常量池技能,但他们掩护的常量仅仅是【-128至127】这个范围内的常量,如果常量值超过这个范围,就会从堆中创建工具,不再从常量池中取。比如,把上边例子改成Integer i1 = 400; Integer i2 = 400;,很明显超过了127,无法从常量池获取常量,就要从堆中new新的Integer工具,这时i1和i2就不相等了。
2.String类型也实现了常量池技能,但是轻微有点不同。String型是先检测常量池中有没有对应字符串,如果有,则取出来;如果没有,则把当前的添加进去。