• ==的分析

    1.对于基本数据类型,比较的是他们的具体内容是不是一样,跟他们的内存地址无关。举个栗子:

    public class Test{
    
    	public static void main(String[] args) {
    int i = 10;
    double j = 10.0;
    float m = 10.0f;
    char k = 10;
    boolean b = true; System.out.println(i == j);
    System.out.println(i == m);
    System.out.println(m == k);
    System.out.println("*******************");
    //System.out.println(i == b); 很明显,布尔型不能和其他基本数据类型比较,编译报错.
    System.out.println(System.identityHashCode(i));
    System.out.println(System.identityHashCode(j));
    System.out.println(System.identityHashCode(m));
    System.out.println(System.identityHashCode(k));
    System.out.println(System.identityHashCode(b));
    }
    }

    输出结果:

    true
    true
    true
    *******************
    366712642
    1829164700
    2018699554
    1311053135
    118352462

    分析:

    ​ ①根据比较的结果和内存地址来看,内容一样,内存地址不一样,但是返回的结果都是true,说明比较的 时候只看变量中存储的内容是否相同,而跟内存地址无关。

    ​ ②==比较的两边数据需要能强制转换成同一类型,比如intdouble的比较,会强制转换到double

    ​ ③布尔类型不能和int,float,double,char等基本数据类型做比较,编译时就报错。

    2.对于引用数据类型的比较:

    public class Test{
    
    	public static void main(String[] args) {
    Test t1 = new Test();
    Test t2 = new Test();
    String name1 = "琼宝";
    String name2 = "琼宝"; System.out.println(name1 == name2); // true
    System.out.println(System.identityHashCode(name1)); //366712642
    System.out.println(System.identityHashCode(name2)); //366712642 System.out.println(t1 == t2); //false
    System.out.println(System.identityHashCode(t1)); //366712642
    System.out.println(System.identityHashCode(t2)); //1829164700
    System.out.println(System.identityHashCode(new Test())); //2018699554
    System.out.println(System.identityHashCode(new Test())); //1311053135
    System.out.println(new Test() == new Test());
    }
    }

    输出结果:

    true
    366712642
    366712642
    false
    366712642
    1829164700
    2018699554
    1311053135
    false

    分析:

    ​ ①对于引用数据类型,此时涉及到两块内存的问题, 而且比较的也是内存地址是否相同,比如执行语句

    Test t1 = new Test() Test t2 = new Test()时,会开辟两块内存,一块用于储存t1 t2 ,一 块用于储存两个 new Test()。而很明显的是,t1和t2的内存地址不一样,就连两个new Test()的地 址都不一样,所以此时用==来比较的时候,结果必然是false.(补充:t1和t2中存储的其实是new Test() 对象使用的内存的首地址。)

    ​ ②对于String类型来说,内容相同的时候,其内存地址也相同,比较的时候看的也是地址。

    ​ ②如果要比较对象中存储的内容是否相同(不是比较地址),那么==就无法实现,此时需要equals.


  • equals的分析

    1.先看一个equals比较的栗子:

    public class TestEquals {
    public static void main(String[] args) { TestEquals t1 = new TestEquals();
    TestEquals t2 = new TestEquals();
    System.out.println(t1.equals(t2)); //false String s1 = new String();
    String s2 = new String(); System.out.println(System.identityHashCode(s1));
    System.out.println(System.identityHashCode(s2));
    System.out.println(System.identityHashCode(new String()));
    System.out.println(System.identityHashCode(new String()));
    System.out.println(s1.equals(s2)); // true
    }
    } 输出结果:
    false
    366712642
    1829164700
    2018699554
    1311053135
    true

    2.分析:

    ​ ①t1和t2的比较是false,而s1和s2的比较是true,这里就涉及到了equals方法的重写问题,先看 Object类 中equals的源码:

    public boolean equals(Object obj) {
    return (this == obj);
    }

    ​ ② 对于s1.equals(s2) ,this就是s1,obj是s2,而源码中的比较用的是==,很明显是引用数据类型的比 较,看的是s1和s2的内存地址,上面的分析已经知道他们的地址不一样,所以结果自然就是false.

    ​ ③而s1和s2的比较结果是true,这是因为在String类中,equals方法被重写了,看源码:

    public boolean equals(Object anObject) {
    if (this == anObject) {
    return true;
    }
    if (anObject instanceof String) {
    String anotherString = (String)anObject;
    int n = value.length;
    if (n == anotherString.value.length) {
    char v1[] = value;
    char v2[] = anotherString.value;
    int i = 0;
    while (n-- != 0) {
    if (v1[i] != v2[i])
    return false;
    i++;
    }
    return true;
    }
    }
    return false;
    }

    ​ ④通过和object中equals源码的对比可以看出,String中的equals方法比较的不再是对象的地址,而是看 两个对象内容,或者两个对象的属性是否都一样。

    ​ ⑤像String,Date,File…等类都对equals方法进行了重写。


  • 总结

    1.==用于比较基本数据类型时,比较的是内容是否相等,比较引用数据类型时,看的是内存地址是否相等。

    2.equals只能比较引用数据类型(对象),没被重写之前,使用==来比较内存地址,重写后比较的是对象的具 体内容和属性是否一致。

    3.创作不易。感谢支持,欢迎转载转发,但请注明出处。

    4.如对你有帮助,老板大气,感谢打赏一杯熬夜咖啡。

    5 .QQ 321662487

==和equals的深度分析的更多相关文章

  1. java集合框架(1) hashMap 简单使用以及深度分析(转)

    java.util 类 HashMap<K,V>java.lang.Object  java.util.AbstractMap<K,V>      java.util.Hash ...

  2. const与readonly深度分析(.NET)

    前言 很多.NET的初学者对const和readonly的使用很模糊,本文就const和readonly做一下深度分析,包括: 1. const数据类型的优势 2. const数据类型的劣势 3. r ...

  3. 转:[gevent源码分析] 深度分析gevent运行流程

    [gevent源码分析] 深度分析gevent运行流程 http://blog.csdn.net/yueguanghaidao/article/details/24281751 一直对gevent运行 ...

  4. 深度分析 Java 的枚举类型:枚举的线程安全性及序列化问题(转)

    写在前面: Java SE5 提供了一种新的类型 Java的枚举类型,关键字 enum 可以将一组具名的值的有限集合创建为一种新的类型,而这些具名的值可以作为常规的程序组件使用,这是一种非常有用的功能 ...

  5. AndroidService 深度分析(2)

    AndroidService 深度分析(2) 上一篇文章我们Service的生命周期进行了測试及总结. 这篇文章我们介绍下绑定执行的Service的实现. 绑定执行的Service可能是仅为本应用提供 ...

  6. 深度分析如何在Hadoop中控制Map的数量

    深度分析如何在Hadoop中控制Map的数量 guibin.beijing@gmail.com 很多文档中描述,Mapper的数量在默认情况下不可直接控制干预,因为Mapper的数量由输入的大小和个数 ...

  7. MapReduce深度分析(二)

    MapReduce深度分析(二) 五.JobTracker分析 JobTracker是hadoop的重要的后台守护进程之一,主要的功能是管理任务调度.管理TaskTracker.监控作业执行.运行作业 ...

  8. MapReduce深度分析(一)

    MapReduce深度分析(一) 一.数据流向分析 图为MapReduce数据流向示意图 步骤1.输入文件从HDFS流向到Mapper节点.在一般情况下,存储数据的节点就是Mapper运行的节点,不需 ...

  9. 【JVM】深度分析Java的ClassLoader机制(源码级别)

    原文:深度分析Java的ClassLoader机制(源码级别) 为了更好的理解类的加载机制,我们来深入研究一下ClassLoader和他的loadClass()方法. 源码分析 public abst ...

随机推荐

  1. linux添加、删除、升级软件包 yum rpm dpkg

    1.红帽7主要采用yum和rpm SN command   1 rpm -qa --query  --all. 2 rpm -ql <package> 列出包中的文件 3 rpm -ivh ...

  2. 十、GAP

    1.1     背景 GAP(Generic Access Profile)位于主机协议栈的最顶层,用来定义BLE设备在待机或者连接状态中的行为,该Profile保证不同的Bluetooth产品可以互 ...

  3. js数组之sort()函数

    一般我们使用sort函数进行数组的排序,sort()方法有一个可选参数,是用来确定元素顺序的函数.如果这个参数被省略,那么数组中的元素将按照ASCII字符顺序进行排序.如: var arr = [&q ...

  4. echarts绘制彩虹色背景

    大致成品如图所示 关键的步骤: var dom = document.getElementById("myChart"); var myChart = echarts.init(d ...

  5. 2019-9-17:渗透测试,基础学习,apache初识,mysql初识等笔记

    python -m SimpleHTTPServer gedit 文本编辑器 apache2 默认配置文件目录:/etc/apache2/apache2默认首页源码: /var/www/html my ...

  6. Photoshop CS5软件安装教程

    Photoshop CS5(32/64位)精简版下载地址: 链接:https://pan.baidu.com/s/11T-L-aH3JNXlJmSqL0JY6Q提取码:ea5j Photoshop主要 ...

  7. php+redis实现注册、删除、编辑、分页、登录、关注等功能

    本文实例讲述了php+redis实现注册.删除.编辑.分页.登录.关注等功能.分享给大家供大家参考,具体如下: 主要界面 ​ 连接redis redis.php <?php //实例化 $red ...

  8. jvm垃圾回收器与内存分配策略

    一.判断对象存活的算法 1.引用计数算法 (1)概念:给对象中添加一个引用计数器每当有一个地方引用它时,计数器值加1:当引用失效时,计数器就减1:任何时刻计数器为0的对象就是不可能再被使用的. (2) ...

  9. vsftp安装和配置

    2013-10-10 10:49:48|  分类: Linux|举报|字号 订阅     源码下载地址:ftp://vsftpd.beasts.org/users/cevans/untar/   1. ...

  10. String类中常用的方法

    @Test public void demo(){ // 以下为String中的常用的方法及注释, 最常用的注释前有**标注 String s = "abcdefg123456"; ...