当前位置: 首页 > news >正文

java中的equals方法

这个方法首先比较的是两个对象的地址是否相同,如果相同直接返回true,

否则, (1)如果是string类型的先比较是否是string类型,是的话,再比较是否长度相同,相同的话再比较,每个字符是否相同;

   (2)判断两个对象是否是同一个类加载器加载的,不是则返回false;

   (3)如果是普通对象则将对象的属性放入hashmap中作为key, 属性中的值作为value,以此作为比较的方式。

hashcode()方法,是native方法

对于包含容器类型的程序设计语言来说,基本上都会涉及到hashCode。在Java中也一样,hashCode方法的主要作用是为了配合基于散列的集合一起正常运行,这样的散列集合包括HashSet、HashMap以及HashTable。

  为什么这么说呢?考虑一种情况,当向集合中插入对象时,如何判别在集合中是否已经存在该对象了?(注意:集合中不允许重复的元素存在)

  也许大多数人都会想到调用equals方法来逐个进行比较,这个方法确实可行。但是如果集合中已经存在一万条数据或者更多的数据,如果采用equals方法去逐一比较,效率必然是一个问题。此时hashCode方法的作用就体现出来了,当集合要添加新的对象时,先调用这个对象的hashCode方法,得到对应的hashcode值,实际上在HashMap的具体实现中会用一个table保存已经存进去的对象的hashcode值,如果table中没有该hashcode值,它就可以直接存进去,不用再进行任何比较了;如果存在该hashcode值, 就调用它的equals方法与新元素进行比较,相同的话就不存了,不相同就散列其它的地址,所以这里存在一个冲突解决的问题,这样一来实际调用equals方法的次数就大大降低了,说通俗一点:Java中的hashCode方法就是根据一定的规则将与对象相关的信息(比如对象的存储地址,对象的字段等)映射成一个数值,这个数值称作为散列值。下面这段代码是java.util.HashMap的中put方法的具体实现:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public  V put(K key, V value) {
         if  (key ==  null )
             return  putForNullKey(value);
         int  hash = hash(key.hashCode());
         int  i = indexFor(hash, table.length);
         for  (Entry<K,V> e = table[i]; e !=  null ; e = e.next) {
             Object k;
             if  (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
                 V oldValue = e.value;
                 e.value = value;
                 e.recordAccess( this );
                 return  oldValue;
             }
         }
 
         modCount++;
         addEntry(hash, key, value, i);
         return  null ;
     }

  put方法是用来向HashMap中添加新的元素,从put方法的具体实现可知,会先调用hashCode方法得到该元素的hashCode值,然后查看table中是否存在该hashCode值,如果存在则调用equals方法重新确定是否存在该元素,如果存在,则更新value值,否则将新的元素添加到HashMap中。从这里可以看出,hashCode方法的存在是为了减少equals方法的调用次数,从而提高程序效率。

 

两个对象相等hashcode一定相等。

两个对象的hashcode相等,则两个对象不一定相等。

所以重写equals方法时, 一般要重写hashcode方法。

下面是一个demo:

public class Student {
private int age;
private String name;

public Student(int age, String name) {
this.age = age;
this.name = name;
}

@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;

Student student = (Student) o;

if (age != student.age) return false;
return name.equals(student.name);
}

@Override
public int hashCode() {
int result = age;
result = 31 * result + name.hashCode();
return result;
}
}

转载于:https://www.cnblogs.com/wangnuo/p/7744891.html

相关文章:

  • 【BZOJ5060】魔方国 特判
  • set与multiset
  • 集体智慧编程笔记
  • 【探路者】第三周立会报告6(总第18次)
  • 如何在Windows下安装Linux子系统(Ubuntu,openSUSU,SUSU Linux Server)
  • 很想说点什么
  • 使用vue-cli构建vue项目流程
  • Python学习笔记(1)-列表
  • 【20171103中】sqli-libs Less 40-49
  • 迷宫问题
  • js:字符串(string)转json
  • 硬币收集问题
  • 无缝连续滚动
  • Django--权限组件
  • 电子凭证 : Java 生成 Pdf
  • 【Leetcode】104. 二叉树的最大深度
  • 【刷算法】从上往下打印二叉树
  • 78. Subsets
  • CSS实用技巧干货
  • es6(二):字符串的扩展
  • IOS评论框不贴底(ios12新bug)
  • JavaScript设计模式之工厂模式
  • Java方法详解
  • java小心机(3)| 浅析finalize()
  • python学习笔记-类对象的信息
  • ReactNative开发常用的三方模块
  • Spring Boot MyBatis配置多种数据库
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • 简单实现一个textarea自适应高度
  • 老板让我十分钟上手nx-admin
  • 你不可错过的前端面试题(一)
  • AI又要和人类“对打”,Deepmind宣布《星战Ⅱ》即将开始 ...
  • 哈罗单车融资几十亿元,蚂蚁金服与春华资本加持 ...
  • ​520就是要宠粉,你的心头书我买单
  • ###51单片机学习(1)-----单片机烧录软件的使用,以及如何建立一个工程项目
  • #{} 和 ${}区别
  • #laravel 通过手动安装依赖PHPExcel#
  • #Linux(权限管理)
  • #stm32整理(一)flash读写
  • $().each和$.each的区别
  • (react踩过的坑)antd 如何同时获取一个select 的value和 label值
  • (二)PySpark3:SparkSQL编程
  • (附源码)ssm基于jsp高校选课系统 毕业设计 291627
  • (原創) 未来三学期想要修的课 (日記)
  • (转)ObjectiveC 深浅拷贝学习
  • (转)编辑寄语:因为爱心,所以美丽
  • (转)我也是一只IT小小鸟
  • ..回顾17,展望18
  • .NET Core工程编译事件$(TargetDir)变量为空引发的思考
  • .Net 路由处理厉害了
  • .net 无限分类
  • .NET/C# 避免调试器不小心提前计算本应延迟计算的值
  • .NET/C# 的字符串暂存池
  • .Net调用Java编写的WebServices返回值为Null的解决方法(SoapUI工具测试有返回值)
  • .net和php怎么连接,php和apache之间如何连接