zoukankan      html  css  js  c++  java
  • Java基础之==与equal()的区别

     

     

      从刚学java起,对于==与euqal()之间的区别就一直模糊不清,搞了又搞,一直搞不明白,今天决定彻底搞懂。。。。

      参考博客:http://www.cnblogs.com/pop822/p/6215040.html

            http://www.jb51.net/article/73949.htm

      问题分析:(1)==与equal()各自的作用

         (2)与引用数据类型,基本数据类型综合以后应该怎么分析

         (3)项目中使用应该注意什么

       

      作用:== 操作比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量在堆中存储的地址是否相同,即栈中的内容是否相同。

            equals操作表示的两个变量是否是对同一个对象的引用,即堆中的内容是否相同。

          ==一般用在基本数据类型中,equals()一般比较字符串是否相等

          比如:

             String s1 = "Monday";

               String s2 = "Monday";

            s1==s1 //true,因为s1,s2的值均存放在常量池中,s1,s1在栈中存放常量池中位置相同

        

            String s1 = "Monday";

               String s2 = new String("Monday");

            s1==s2;    //false

            s1.equals(s2);   //true

            

            原来,程序在运行的时候会创建一个字符串缓冲池当使用 s2 = "Monday" 这样的表达是创建字符串的时候,程序首先会在这个String缓冲池中寻找相同值的对象,在第一个程序中,s1先被放到了池中,所以在s2被创建的时候,程序找到了具有相同值的 s1

               将s2引用s1所引用的对象"Monday"

                第二段程序中,使用了 new 操作符,他明白的告诉程序:"我要一个新的!不要旧的!"于是一个新的"Monday"Sting对象被创建在内存中。他们的值相同,但是位置不同,一个在池中游泳一个在岸边休息。哎呀,真是资源浪费,明明是一样的非要分开做什么呢?

            

      结论:要想判断两个对象是否相等,不能通过比较两个对象的引用是否相等,这是永远都得不到相等的结果的,因为两个对象的引用永远不会相等,所以正确的比较方法是直接比较这两个对象,比较这两个对象的实质是不是一样的,即这两个对象里面的内容是不是相同的,通过比较这两个对象的属性值是否相同而决定这两个对象是否相等。

      所以通过重写类中的equal()方法

          

        一般我们在设计一个类时,需要重写父类的equals方法,在重写这个方法时,需要按照以下几个规则设计:
        1、自反性:对任意引用值X,x.equals(x)的返回值一定为true.
        2、对称性:对于任何引用值x,y,当且仅当y.equals(x)返回值为true时,x.equals(y)的返回值一定为true;
        3、传递性:如果x.equals(y)=true, y.equals(z)=true,则x.equals(z)=true
        4、一致性:如果参与比较的对象没任何改变,则对象比较的结果也不应该有任何改变
        5、非空性:任何非空的引用值X,x.equals(null)的返回值一定为false

          

    equas()与==就这么多,忘了就来看看,应该就能理解

     

     Integer:   -128 ------------127 之间走的是缓存

    public static Integer valueOf(int i) {
        if (i >= IntegerCache.low && i <= IntegerCache.high)
            return IntegerCache.cache[i + (-IntegerCache.low)];
        return new Integer(i);
     
    1. public static Integer valueOf(int i) {
    2.  
      if (i >= IntegerCache.low && i <= IntegerCache.high)
    3.  
      return IntegerCache.cache[i + (-IntegerCache.low)];
    4.  
      return new Integer(i);
    5.  
  • 相关阅读:
    LaTeX下的表格处理
    accumulate函数用法的坑
    将博客搬至CSDN
    linux; 文件名乱码;问价名出现问号
    vim打开多窗口、多文件之间的切换
    关于ssh-server
    更改Ubuntu gcc、g++默认编译器版本
    Elasticsearch nest实现类似Contains和Like功能
    Redis大幅性能提升之Batch批量读写
    Ext.NET 4.1 系统框架的搭建(后台) 附源码
  • 原文地址:https://www.cnblogs.com/kelelipeng/p/12307053.html
Copyright © 2011-2022 走看看