int与Integer详解(java基础篇)

前言

在回顾==与equals的区别于联系时,我们很清楚的了解到:
==:可以用于基本数据类型的比较,也可以用于对象进行比。,对于基本数据类型,比较的是值;对于引用数据类型,比较的是内存地址
equals:Object类的Native方法,本质等同于“==”,比较内存地址;但我们常用的String、Integer等都对equals方法进行了重写,使其变成了值的比较。
那么就会有疑问了,那基本类型和引用类型的比较呢,这就涉及到我们的八种基本数据类型及它们的封装数据类型的对比。下面我们根据实例讲解:

        int int1 = 2;
        int int2 = 2;
        Integer integer1 = 2;
        Integer integer2 = 2;
        Integer newInteger1 = new Integer(2);
        Integer newInteger2 = new Integer(2);
        //1
        System.out.println("int1与int2的==:" + (int1 == int2));//true
        //int1与int2是基本数据类型,不能使用。equals对比
        //2
        System.out.println("integer1与integer2的==:" + (integer1 == integer2));//true
        //3
        System.out.println("integer1与integer2的equals:" + (integer1.equals(integer2)));//true

        //4
        System.out.println("newInteger1与newInteger2的==:" + (newInteger1==newInteger2));//false
        //5
        System.out.println("newInteger1与newInteger2的equals:" + (newInteger1.equals(newInteger2)));//true
        //6
        System.out.println("int1与integer1的==:" + (int1==integer1));//true
        //7
        System.out.println("int1与integer1的equals:" + (integer1.equals(int1)));//true
        
        //8
        System.out.println("int1与newInteger1的==:" + (int1==newInteger1));//true

        //9
        System.out.println("integer1与newInteger1的==:" + (integer1==newInteger1));//false
        //10
        System.out.println("integer1与newInteger1的equals:" + (integer1.equals(newInteger1)));//true

详情解析如下:
1返回true
无需过多解释,基本数据类型比较值
2返回true
我们先来看下Integer ingteger1=2;这种写法在jdk1.5版本之前是不允许的,从1.5版本开始java引入了自动装箱拆箱机制,这个赋值操作等同于:Integer integer1= Integer.valueOf(2);2中的对比也就是两个自动装箱的变量进行比较,那为什么返回的不是false?查看一下Integer的valueOf源码:

    /**
     * Returns an {@code Integer} instance representing the specified
     * {@code int} value.  If a new {@code Integer} instance is not
     * required, this method should generally be used in preference to
     * the constructor {@link #Integer(int)}, as this method is likely
     * to yield significantly better space and time performance by
     * caching frequently requested values.
     *
     * This method will always cache values in the range -128 to 127,
     * inclusive, and may cache other values outside of this range.
     *
     * @param  i an {@code int} value.
     * @return an {@code Integer} instance representing {@code i}.
     * @since  1.5
     */
    public static Integer valueOf(int i) {
        if (i >= IntegerCache.low && i <= IntegerCache.high)
            return IntegerCache.cache[i + (-IntegerCache.low)];
        return new Integer(i);
    }

可以看出,如果取值范围在-128-127,会在数组(这个数组里面缓存了基本类型-128-127之间的Integer对象)中获取对象,否则重新new一个Integer对象,我们2中赋值为2,所以返回true,如果大于127或小于128,则返回false。
3返回true
Integer重写了equals方法,两个自动装箱的Integer对象,比较value。
4和5返回true 不再解释
6返回true
基本数据类型int1和integer1自动装箱类型变量对比时,integer1进行自动拆箱操作,拆箱完成,也就是两个基本数据类型值的比较。这一步可能会有疑问,为什么是integer1拆箱而不是int1装箱?其实这块是java根据一个很明显的道理进行设计的:如果有人比较一个int类型的值和Integer类型的值,是想比较什么呢?肯定是值呀,所以这块是对Integer对象进行拆箱而不是对int类型装箱了

public int intValue()  
{  
  return value;  
}

7返回true
调用equals方法的肯定是Integer对象,但是Integer类中重写的equals方法参数是一个Object类型呀,怎么能传递一个基本数据类型进去呢?所以,这块又是一个自动装箱的表现,当传递一个int类型给equals这个方法时,java会自动将这个值打包装箱为Integer类,然后就是两个Integer对象进行equals判断
8返回true
int1为一个基本类型int,newInteger1是一个Integer对象,进行==比较的时候,会对Integer对象进行拆箱处理,所以结果为true(等同于6)。
9返回false
自动装箱的integer1和newInteger1都是Integer对象(等同于4)。
10返回false
自动装箱的integer1和newInteger1都是Integer对象(等同于5)。

总结

对于封装数据类型的对比,涉及自动装箱拆箱操作,使用需谨慎~~~

你可能感兴趣的:(int与Integer详解(java基础篇))