两者的区别:

A:==

基本类型:比较的是值是否相同

引用类型:比较的是地址值是否相同

B:equals()

只能比较引用类型。

默认情况下,比较的是地址值是否相同,因为我们可以看源代码可以看到,在Object类中该方法的比较是用==比较的

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

。比如当我们想要比较两个引用类型的某些内容是否相等(student类中学生姓名或者年龄是否相等),这时比较地址值是没有意义的,所以我们一般会重写该方法,因为该方法是Object类中的方法,一般用快捷键重写equals方法(Alt+Shift+S)。在系统API中的类都自己重写了equals方法,所以直接调用比较的实际上是比较对象的值是否相等,而不是比较对象的地址值。而我们自己写的类。比如学生Student类等等,如果不重写equals方法,则默认是比较对象的地址值,所以要比较对象的值时候都会重写该方法。如下代码:

public class Equal {

	public static void main(String[] args) {
		Integer a1 = new Integer(10);
		Integer a2 = new Integer(10);
		System.out.println(a2.equals(a2));//true
		System.out.println(a1 == a2);//false
		System.out.println("------------");
		String a = new String("ha");
		String b = new String("ha");
		System.out.println(a.equals(b));//true
		System.out.println(a == b);//false
		System.out.println("------------");
		<span style="color:#ff0000;">Student s1 = new Student(10);
		Student s2 = new Student(10);
		Student s3 = s1;
		System.out.println(s1.equals(s3));//true
		System.out.println(s1.equals(s2));//false
		System.out.println(s1 == s2);//false</span>
		System.out.println("------------");
		int s4 = 3;
		int s5 = 3;
		//System.out.println(s4.equals(s5));//会报错,equals只能比较引用类型
		System.out.println(s5 == s4);//true
		System.out.println("------------");
		String s6 = "ha";
		String s7 =new String("ha");
		System.out.println(s6.equals(s7));//true
		System.out.println(s6 == s7);//flase
		System.out.println("------------");
		ArrayList list1 = new ArrayList();
		list1.add("aa");
		ArrayList list2 = new ArrayList();
		list2.add("aa");
		System.out.println(list1.equals(list2));//true
		System.out.println(list1 == list2);//false
		System.out.println("------------");
		ArrayList list3 = new ArrayList();
		list1.add("aa");
		ArrayList list4 = new ArrayList();
		list2.add("bb");
		System.out.println(list1.equals(list2));//false
		System.out.println(list1 == list2);//false
		//==在基本类型中比较的是值,在引用类型中比较的是地址值
	}

}

class Student {
	private int age;
	public Student(int age) {
		this.age = age;
	}
	//没有重写equals方法,则调用的是Object中的,默认比较地址值
}

在Student类中重写equals方法后:

<pre name="code" class="java">Student s1 = new Student(10);
Student s2 = new Student(10);

s1.equals(s2);//就为true


class Student {
	private int age;
	public Student(int age) {
		this.age = age;
	}
	//重写equals方法
	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		Student other = (Student) obj;
		if (age != other.age)
			return false;
		return true;
	}

}
<span style="white-space:pre">		</span>Student s1 = new Student(10);
<span style="white-space:pre">		</span>Student s2 = new Student(10);
<span style="white-space:pre">		</span>Student s3 = s1;
<span style="white-space:pre">		</span>System.out.println(s1.equals(s3));//true
<span style="white-space:pre">		</span>System.out.println(s1.equals(s2));//<span style="color:#ff0000;">true</span>
<span style="white-space:pre">		</span>System.out.println(s1 == s2);//false

其它的一些方法:

A:hashCode() 返回对象的哈希值,根据哈希算法计算出来的一个值,这个值和地址值有关,但不是实际地址值。

B:getClass() 返回对象的字节码文件对象

C:finalize() 用于垃圾回收,在不确定的时间

D:clone() 可以实现对象的克隆,包括成员变量的数据复制,它是在堆内存新创建了一个一模一样的对象,但是要克隆的类必须实现该Cloneable接口:实现了 Cloneable 接口,以指示 Object.clone() 方法可以合法地对该类实例进行按字段复制。 这个个接口是标记接口,没有方法,告诉我们实现该接口的类就可以实现对象的复制了。

Java之equals和==详解的更多相关文章

  1. java反射机制深入详解

    java反射机制深入详解  转自:http://www.cnblogs.com/hxsyl/archive/2013/03/23/2977593.html 一.概念 反射就是把Java的各种成分映射成 ...

  2. java.util.Scanner应用详解++扫描控制台输入

    java.util.Scanner应用详解   java.util.Scanner是Java5的新特征,主要功能是简化文本扫描.这个类最实用的地方表现在获取控制台输入,其他的功能都很鸡肋,尽管Java ...

  3. (转)java.util.Scanner应用详解

    java.util.Scanner应用详解   java.util.Scanner是Java5的新特征,主要功能是简化文本扫描.这个类最实用的地方表现在获取控制台输入,其他的功能都很鸡肋,尽管Java ...

  4. java网络编程(TCP详解)

    网络编程详解-TCP 一,TCP协议的特点              面向连接的协议(有发送端就一定要有接收端)    通过三次连接握手建立连接 通过四次握手断开连接 基于IO流传输数据 传输数据大小 ...

  5. Java基础学习总结(24)——Java单元测试之JUnit4详解

    Java单元测试之JUnit4详解 与JUnit3不同,JUnit4通过注解的方式来识别测试方法.目前支持的主要注解有: @BeforeClass 全局只会执行一次,而且是第一个运行 @Before  ...

  6. Java 8 Stream API详解--转

    原文地址:http://blog.csdn.net/chszs/article/details/47038607 Java 8 Stream API详解 一.Stream API介绍 Java8引入了 ...

  7. 国际化,java.util.ResourceBundle使用详解

    java.util.ResourceBundle使用详解   一.认识国际化资源文件   这个类提供软件国际化的捷径.通过此类,可以使您所编写的程序可以:          轻松地本地化或翻译成不同的 ...

  8. java之StringBuffer类详解

    StringBuffer 线程安全的可变字符序列. StringBuffer源码分析(JDK1.6): public final class StringBuffer extends Abstract ...

  9. java.util.ResourceBundle使用详解

    java.util.ResourceBundle使用详解   一.认识国际化资源文件   这个类提供软件国际化的捷径.通过此类,可以使您所编写的程序可以:          轻松地本地化或翻译成不同的 ...

随机推荐

  1. Ubantu16.04系统优化

    系统清理篇 系统更新 安装完系统之后,需要更新一些补丁.Ctrl+Alt+T调出终端,执行一下代码: sudo apt-get update sudo apt-get upgrade 卸载libreO ...

  2. CodeForces - 724G:Xor-matic Number of the Graph

    两点之间的任意路径都可表示为  随便某一条路径xor任何多个环, 然后可以用线性基来做,这样不会重复的, 另外必须一位一位的处理,xor是不满足结合律的 #include<cstdio> ...

  3. 【线段树】【BZOJ1798】【AHOI2009】维护序列

    还是那个学弟@lher出的丧题之一. 链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798 题意简析:就是题目啊... 解题思路:显然是线段树 ...

  4. solr6.6初探之solrj

    一. solrj简介: solrj可以使Java应用程序很方便的访问与操作solr.solrj有几个核心类,分别为:1.SolrClient 2.SolrRequests 3.SolrQuerys 4 ...

  5. 新版Eclipse打开jsp、js等为文本编辑,没有JSP Editor插件问题

    刚从官网下载安装的Eclipse Java Oxygen.2但是打开的jsp文件尽然默认文本编辑器打开,就js文件也是一样,纳闷! 网上搜索一番,原来缺少web开发相关工具, 下面给插件安装方法: 1 ...

  6. I/O控制的主要功能

    主要功能: 1.  解释用户的I/O系统调用.将用户I/O系统调用转换为I/O控制模块认识的命令模式. 2.  设备驱动.根据得到的I/O命令,启动物理设备完成指定的I/O操作. 3.  中断处理.对 ...

  7. python 2week

    本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 1 names =  ...

  8. Mybatis之一级缓存,二级缓存

    一级缓存:Mybatis的一级缓存在session上,只要通过session查过的数据,都会放在session上,下一次再查询相同id的数据,都直接冲缓存中取出来,而不用到数据库里去取了. 二级缓存: ...

  9. Windows 下 Ionic 开发环境搭建

    Ionic 介绍 首先,Ionic 是什么. Ionic 是一款基于 Cordova 及 Angular 开发 Hybrid/Web APP 的前端框架,类似的其他框架有:Intel XDK等. 简单 ...

  10. ThreadLocal基本原理及运用

    ThreadLocal提供本地线程变量.这个变量里面的值(通过get方法获取)是和其他线程分割开来的,变量的值只有当前线程能访问到,不像一般的类型比如Person,Student类型的变量,只要访问到 ...