HashSet介绍
(1) 为啥要用HahSet?
假如我们现在想要在一大堆数据中查找X数据。LinkedList的数据结构就不说了,查找效率低的可怕。ArrayList哪,如果我们不知道X的位置序号,还是一样要全部遍历一次直到查到结果,效率一样可怕。HashSet天生就是为了提高查找效率的。
(2) hashCode 散列码
散列码是由对象导出的一个整数值。在Object中有一个hashCode方法来得到散列码。基本上,每一个对象都有一个默认的散列码,其值就是对象的内存地址。但也有一些对象的散列码不同,比如String对象,它的散列码是对内容的计算结果:
Java代码
//hashCode与equals方法的兼容public class Employee{ public int id; public String name=""; //相同id对象具有相同散列码 public int hashCode(){ return id; } //equals必须比较id public boolean equals(Employee x){ if(this.id==x.id) return true; else return false; }}