Java基础日常问题分析:
1.自动拆箱装箱的int 和Integer比较:
public class CompareInteger {
public static void main(String[] args) {
Integer i1 = 59;
Integer i2 = Integer.valueOf(59);
int i3 = 59;
Integer i4 = new Integer(59);
System.out.println(i1 == i2);//true
System.out.println(i1 == i3);//true
System.out.println(i1 == i4);//false
System.out.println(i2 == i3);//true
System.out.println(i2 == i4);//false
System.out.println(i3 == i4);//true
}
}
- 首先new出来的Integer无论是和Integer还是int做比较都为false,不用管是否会有数值范围的限定;
- int类型和其包装类Integer类比较时会有自动拆箱和装箱,只要值相等,则必相等
- 当值在[-128,127)之间时,Integer和Integer.valueof所取得值是常量池中的int类型的数据,这个时候只要双方都不是调用new方法构造的,就相等。可以看Integer源码中关于静态valueof的方法
public static Integer valueOf(int arg) {
return arg >= -128 && arg <= Integer.IntegerCache.high ? Integer.IntegerCache.cache[arg + 128]
: new Integer(arg);
}
public Integer(int arg0) {
this.value = arg0;
}
2.数据强制转换时,值越界出现的情况:
public class TransDemoOfNumber {
public static void main(String[] args) {
short s1 = 128;
byte b1 = (byte) s1;
System.out.println(b1);// -128
}
}
- byte的范围是[-128,127),所以打印出来不可能是128,这题在很多基础考试或者面试中会被问到,最大的迷惑选项就是128,这个不用计算就知道肯定是不可能的选项,具体实现需要知道两种数据在java中的存储形式:
- short的128 储存的为:0000 0000 1000 0000,占用两个byte,将其强转就是将前8位砍掉,变成1000 0000;这表示-0,但是byte只有0,-0用来表示-128
持续更新修改。。。