Java之hashCode的作用和equals方法的重构规则
这个是博主对hashcode的初步理解,以后加深了会再来更新:
1、hashcode是什么?
hashcode是对象的散列码,不同的对象几乎不一样,说几乎是因为还是可以一样的。
特点:每一个对象都有hashcode,默认的值是每一个对象的地址。
2、hashcode的作用:
博主已知的方便用户使用散列表插入数据,我们知道,集合有两种,list----可重复,set----不可重复。
其中set实现不可重复就需要使用到hashcode和equals方法。
散列表set是使用链表数组实现的,每一个列表被称作桶,而查找表中对象的位置使用的方法是:
1)、计算对象的散列码hashcode;
2)、公式:hashcode%桶数=索引;eg:某一个对象的散列码是76268,有128个桶,那么对应的这个对象的位置就是在第108个桶中。
而在插入对象到散列表中的时候使用的是同样的过程,只是这个时候可能会发现原有的位置被占用了,桶已经满了,这个时候就需要equals方法进行判断是否相等。
所以:
在重构equals方法的时候一定要重构hashcode方法,不然使用散列表的时候桶都找不到,更不用说下一步的判断是否是同一个对象了。
下面是示例代码:
public static void main(String[] args) {
String hello = "hello";
StringBuilder helloSB = new StringBuilder(hello);
String hello2 = "hello";
StringBuilder hello2SB = new StringBuilder(hello2);
System.out.println("hello's hashcode:" + hello.hashCode());
System.out.println("helloSB's hashcode:" + helloSB.hashCode());
System.out.println("hello2's hashcode:" + hello2.hashCode());
System.out.println("hello2SB's hashcode:" + hello2SB.hashCode());
Set stringSet = new HashSet();
Set sbSet = new HashSet();
stringSet.add(hello);
System.out.println("======" + stringSet.contains(hello2));
stringSet.add(hello2);
sbSet.add(helloSB);
sbSet.add(hello2SB);
Person person1 = new Person(1, "eke");
Person person2 = new Person(1, "eke");
Set personSet = new HashSet();
personSet.add(person1);
personSet.add(person2);
PersonWithHashCode code1 = new PersonWithHashCode(1, "eke");
PersonWithHashCode code2 = new PersonWithHashCode(1, "eke");
Set codeSet = new HashSet();
codeSet.add(code1);
codeSet.add(code2);
System.out.println(stringSet.size());
System.out.println(sbSet.size());
System.out.println(personSet.size());
System.out.println(codeSet.size());
}
运行结果:
hello's hashcode:99162322
helloSB's hashcode:39219479
hello2's hashcode:99162322
hello2SB's hashcode:2031787571
======true
1
2
2
1
下面是PersonWithHashCode,Person和PersonWithHashCode相比只是缺少了hashCode方法。
贴这个代码还有一点是重构了equals方法,这个方法的重构是要遵循一定规则的(图片来自《java核心技术卷II》):

public class PersonWithHashCode {
private int id;
private String name;
public PersonWithHashCode(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public int hashCode() {
return id * 24 + name.hashCode();
}
@Override
public boolean equals(Object object) {
if (object == this)
return true;
if (object == null)
return false;
if (getClass() != object.getClass())
return false;
PersonWithHashCode person = (PersonWithHashCode) object;
return this.id == person.id
&& Person.StringUtils.compare(name, person.getName());
}
static class StringUtils {
static boolean compare(String a, String b) {
if (a == null && b == null)
return true;
if (a == null && b != null) {
return false;
}
if (a != null && b == null)
return false;
return a.equals(b);
}
}
}
Java之hashCode的作用和equals方法的重构规则的更多相关文章
- Java中hashCode的作用
转 http://blog.csdn.net/fenglibing/article/details/8905007 Java中hashCode的作用 2013-05-09 13:54 64351人阅 ...
- Effective Java 第三版——10. 重写equals方法时遵守通用约定
Tips <Effective Java, Third Edition>一书英文版已经出版,这本书的第二版想必很多人都读过,号称Java四大名著之一,不过第二版2009年出版,到现在已经将 ...
- JAVA 注解的几大作用及使用方法详解
JAVA 注解的几大作用及使用方法详解 (2013-01-22 15:13:04) 转载▼ 标签: java 注解 杂谈 分类: Java java 注解,从名字上看是注释,解释.但功能却不仅仅是注释 ...
- Effective Java 第三版——11. 重写equals方法时同时也要重写hashcode方法
Tips <Effective Java, Third Edition>一书英文版已经出版,这本书的第二版想必很多人都读过,号称Java四大名著之一,不过第二版2009年出版,到现在已经将 ...
- [复习]java中hashCode的作用
1.HashCode的官方文档定义 (1)hashcode方法返回该对象的哈希码值.支持该方法是为哈希表提供一些优点,例如java.util.HashTable提供的哈希表. (2)hashCode的 ...
- 【转】Java中hashCode的作用
以下是关于HashCode的官方文档定义: hashcode方法返回该对象的哈希码值.支持该方法是为哈希表提供一些优点,例如,java.util.Hashtable 提供的哈希表. hashCode ...
- java开发----自定义对象,重写equals方法
javaweb开发中,用到了好多自定义对象,这时候如果不重写equals方法,很多时候都会返回false, 因此我们必须习惯重写这个方法. 重点: 1.equals比较俩对象时比较的是对象引用是否指向 ...
- Java中编写一个完美的equals方法
首先看下Java语言规范对equals方法的要求: 1,自反性,对于任何非控引用x,x.equals(x)都应该返回true. 2,对称性,对于任何引用x和y,如果x.equals(y)返回true, ...
- Java面试题:==运算符与equals方法的区别
据说这个面试题目,80%的程序员都会理直气壮的回答错误!! 一: ==运算符 如果比较的是基本数据类型,则直接比较数值是否相等,返回值为"true or false" 如果比较的是 ...
随机推荐
- Mysql5.7数据导出提示--secure-file-priv选项问题的解决方法
mysql可使用into outfile参数把表中的数据到处到csv,示例如下: select user_id from weibo_comment into outfile '/home/dazha ...
- python&django 实现页面中关联查询小功能(基础篇)
效果 实现效果图如下,根据过滤条件查询相关信息. 知识点 1.配置URL,在路由中使用正则表达式 2.过滤查询 代码 setting.py from django.contrib import adm ...
- SpringMVC使用CommonsMultipartResolver上传文件
DispatcherServlet并没有实现任何解析multipart请求数据的功能,它将该任务委托给了Spring中MultipartResolver策略接口的实现,通过该接口的实现类来解析mult ...
- webpack 打包报错:One CLI for webpack must be installed. These are recommended choices, delivered as separate packages
webpack 打包报错: One CLI for webpack must be installed. These are recommended choices, delivered as sep ...
- [SDOI2009]HH的项链-树状数组/线段树
树状数组: #include<bits/stdc++.h> using namespace std; ; int id[maxn],tree[maxn],vis[maxn],num[max ...
- linux 安装虚拟机
如果虚拟机创建不了就重启电脑 重启时 按下F2 出现后 第二个 往下 有个默认的 那个那个 打开虚拟机 选择第一个 然后是选择语言选择软件里面的 软件选择选择 基本网页服务器(右侧选择 python ...
- WPF 10天修炼 第十天- WPF数据绑定
WPF数据绑定 数据绑定到元素属性是将源对象指定为一个WPF元素,并且源属性是一个依赖属性,依赖属性内置了变更通知.当改变源对象依赖属性值之后,绑定目标可以立即得到更新,开发人员不需要手动编写响应事件 ...
- 解决python查询报%d format: a number is required, not str问题
文章链接:https://blog.csdn.net/u011878172/article/details/72599120 [问题描述] 1.在一条查询语句中,查询条件既包含了整形又包含了字符串型, ...
- (原创)lua日期、时间、时间戳的计算和转换
----------------------------------------------日期与时间 print("当前时间戳:") local nowTime = os.tim ...
- ios设置音乐audio自动播放
因为audio标签的自动播放:autoplay.在ios系统中不能自动播放,此时需要设置,在进入页面自动播放音乐. 第一步,先引入js微信 <script src="js/jweixi ...