zoukankan      html  css  js  c++  java
  • 【java基础】 == 和 equals() 的区别

    ==号和equals()方法都是比较是否相等的方法,那它们有什么区别和联系呢? 

    首先,==号在比较基本数据类型(指的值类型)时比较的是值,而用==号比较两个对象时比较的是两个对象的地址值

    int x = 10;
    int y = 10;
    String str1 = new String("abc");
    String str2 = new String("abc");
    System.out.println(x == y); // 输出true
    System.out.println(str1 == str2); // 输出false
    

    那equals()方法呢?我们可以通过查看源码知道,equals()方法存在于Object类中,因为Object类是所有类的直接或间接父类,也就是说所有的类中的equals()方法都继承自Object类,而通过源码我们发现,Object类中equals()方法底层依赖的是==号,那么,在所有没有重写equals()方法的类中,调用equals()方法其实和使用==号的效果一样,也是比较的地址值,然而,Java提供的所有类中,绝大多数类都重写了equals()方法,重写后的equals()方法一般都是比较两个对象的值:

    public class Test {
        public static void main(String[] args) {
            Student s1 = new Student(23);
            Student s2 = new Student(23);
            System.out.println(s1.equals(s2));
        }
    }
    
    class Student{
        private int age;
        public Student(){}
    
        public Student(int age){
            this.age = age;
        }
    }
    

    这里自定义了一个Student类,没有重写equals()方法,最后的输出结果是:false

    class Student{
        private int age;
        public Student(){}
    
        public Student(int age){
            this.age = age;
        }
    
        @Override
        public boolean equals(Object obj){
            if (obj instanceof Student) {
                Student stu = (Student) obj;
                return this.hashCode() == stu.hashCode();
            }
            return false;
        }
    
        @Override
        public int hashCode(){
            return this.age;
        }
    }
    

    在重写了equals()方法后,输出结果变成了true。

    现在一些基本的已经讲的差不多了,接下来我们回到第一个例子:

    String str1 = new String("abc");
    String str2 = new String("abc");
    System.out.println(str1.equals(str2));
    System.out.println(str1 == str2);
    

    根据上面所讲,第一个是true,第二个是false,确实如此,那继续看下面的例子:

    String s1 = "abc";
    String s2 = "abc";
    System.out.println(s1.equals(s2));
    System.out.println(s1 == s2);
    

    这次的结果和上一个的是一样的吗?答案是:true true 
    为什么第二个会是true呢? 
    这就涉及到了内存中的常量池,常量池属于方法区的一部分,当运行到s1创建对象时,如果常量池中没有,就在常量池中创建一个对象”abc”,第二次创建的时候,就直接使用,所以两次创建的对象其实是同一个对象,它们的地址值相等。

    那上一个例子中的

    String str1 = new String("abc");
    

    是怎么回事呢? 
    这里其实创建了两次对象,所以str1和str2的地址值不相等。

  • 相关阅读:
    oracle sql日期比较
    rlwrap真是一个好东西
    Dataguard 归档丢失处理
    oracle latch工作原理
    Latch free等待事件
    Redhat Enterprise Linux 5 安装 Oracle 10g release 2
    oracle 日期问题
    Oracle自动存储管理 ASMLib的支持变化
    [官方文档] oracle官方文档总汇(9i,10g,11gR1, 11gR2)
    实时分布式搜索引擎比较(senseidb、Solr、elasticsearch)
  • 原文地址:https://www.cnblogs.com/snaildev/p/9356145.html
Copyright © 2011-2022 走看看