欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

关于==那些事

程序员文章站 2022-05-04 18:53:19
...
        Object o1 =new Object();
        Object o2 =new Object();
        System.out.println(o1.hashCode());   //内存地址  366712642
        System.out.println(o2.hashCode());   //      1829164700
        
        
        String s1="a";                        //常量池
        String s2 = new String("a");          //在栈开辟一块空间存放s2,在堆当中开辟一个块空间存放String实例("a"),s2指向String实例的地址
        String s3 = new String("a");
        System.out.println(s1==s2);          //false     
        System.out.println(s2==s3);          //false   
        System.out.println(s1.hashCode());   //97                  根据传进去的值计算出来某个值
        System.out.println(s2.hashCode());   //97
        
        int i1 = 1;                         //i1指向常量池的1
        Integer i2 = new Integer(1);        
        Integer i3 = new Integer(1);  
        System.out.println(i1==i2);      //true,基本数据类型和引用类型比较的时候,引用类型会自动拆箱为基本数据类型再比较,比较的就是里面的值而不是地址
        System.out.println(i1==i3);     //true  
        System.out.println(i2==i3);    //比较地址、false
        
        char c='a';
        Character b = new Character('a');   
        System.out.println(c==b);        //true

HashCode 就是一个散列码,用来在散列存储结构中确定对象的存储地址。在默认情况下,由 Object 类定义的 hashCode 方法会针对不同的对象返回不同的整数,这一般是通过将该对象的内部地址转换成一个整数来实现的,在每个覆盖了 equals 方法的类中,也必须覆盖 hashCode 方法,在String、Integer、Long等里面都有重新Object的hashCode()方法

由于等号比较的时候是比较两个值的内存地址,因此就算两个值有相同的hashCode也并代表比较出来的结果是true,因为String、Integer、Long等都有重写hashCode()方法