黑马程序员技术交流社区

标题: set方面的问题 [打印本页]

作者: jialihong    时间: 2013-7-23 08:35
标题: set方面的问题
用什么方法判断set集合元素是否重复???

作者: 夜默    时间: 2013-7-23 08:47
HashSet  底层数据结构是哈希表,保证元素的唯一性 hashCode 和equals来完成
  TreeSet   底层数据结构是二叉树 保证元素的唯一性的依据  compareTo方法  
作者: yangqing    时间: 2013-7-23 09:37
常用子类 HashSet  使用的元素的hashCode 方法来确定位置,如果位置相同,再通过元素的equals来比比较内容是否相同。
      TreeSet 元素需要进行比较, 元素需要实现Comparator接口,覆盖compareTo方法 让元素进行比较。

作者: 深圳在漂移    时间: 2013-7-23 10:26
加入Set里面的元素必须定义自己的equals()方法,但是对于良好的设计风格,最好在覆盖equals()方法的同时,也覆盖hashCode()方法,当然,对于TreeSet而言不用覆盖hashCode()方法也可。请记住:覆盖hashCode()方法的目的,只有一个原因就是提高效率。
在往Set中插入新的对象时,首先会用该对象的hashCode()与已经存在对象的hashCode()做比较,如果相等,那就不能插入,如果不等,才会调用equals()方法,如果equals结果为true,说明已经存在,就不能再插入,如果为false,可以插入。
注:如果没有覆盖hashCode()方法,那就是只比较equals().对两个对象equals运算,是判断两个对象是否相等的关键。




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2