首页 > 编程语言 > 详细

Java记录 -56- 详解HashSet不含重复元素的实现

时间:2015-11-03 00:46:48      阅读:264      评论:0      收藏:0      [点我收藏+]

详解HashSet不含重复元素的实现

HashSet的add方法:

public boolean add(E e)

如果此 set 中尚未包含指定元素,则添加指定元素。更确切地讲,如果此 set 没有包含满足 (e==null ? e2==null : e.equals(e2)) 的元素 e2,则向此 set 添加指定的元素 e。如果此 set 已包含该元素,则该调用不更改 set 并返回 false。


Object的equals方法:

public boolean equals(Object obj)

指示其他某个对象是否与此对象“相等”。 

equals 方法在非空对象引用上实现相等关系: 

  • 自反性:对于任何非空引用值 x,x.equals(x) 都应返回 true。 

  • 对称性:对于任何非空引用值 x 和 y,当且仅当 y.equals(x) 返回 true 时,x.equals(y) 才应返回 true。 

  • 传递性:对于任何非空引用值 x、y 和 z,如果 x.equals(y) 返回 true,并且 y.equals(z) 返回 true,那么 x.equals(z) 应返回 true。 

  • 一致性:对于任何非空引用值 x 和 y,多次调用 x.equals(y) 始终返回 true 或始终返回 false,前提是对象上 equals 比较中所用的信息没有被修改。 

  • 对于任何非空引用值 x,x.equals(null) 都应返回 false。 

Object的 equals 方法实现对象上差别可能性最大的相等关系;即,对于任何非空引用值 x 和 y,当且仅当 x 和 y 引用同一个对象时,此方法才返回 true(x == y 具有值 true)。 

注意:当此方法被重写时,通常有必要重写 hashCode 方法,以维护 hashCode 方法的常规协定,该协定声明相等对象必须具有相等的哈希码。


Java记录 -56- 详解HashSet不含重复元素的实现

原文:http://zlfwmm.blog.51cto.com/5892198/1708991

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!