众所周知,Set是一个不包含重复元素的 collection。
不能往里面插入重复的元素。但是,如果先把两个不相同的元素插入到Set里,然后,修改其中一个元素中的值,使两个元素相同,这时Set会怎么处理?
下面利用scjp中的试题,我做了个试验。不够深入还望各位大神,指正。
import java.util.HashSet;
import java.util.Set;
public class Question06 {
public static void main(String[]args) {
MapIt mt = new MapIt();
mt.test();
}
}
class KeyMaster {
public int i = 0;
public KeyMaster(int i) {
this.i = i;
}
public boolean equals(Object other) {
return (i==((KeyMaster)other).i);
}
public int hashCode(){
return this.i;
}
}
class MapIt{
//测试Set的去重功能
public void test(){
KeyMaster k1 = new KeyMaster(1);
KeyMaster k2 = new KeyMaster(2);
Set<KeyMaster> set1 = new HashSet<KeyMaster>();
set1.add(k1);
set1.add(k1);
set1.add(k2);
set1.add(k2);
//尽管往set1里面添加了四次。但是因为有两个重复的,所有这时的size只有2;
System.out.println("(1) set`s size = " + set1.size());
//在这里改变k2中的i值,使k1.equals(k2)==true,k1的hashCode和k2的相同
k2.i = 1;
System.out.println("k1.equals(k2) = " + k1.equals(k2));
System.out.println("k1.hashCode = " + k1.hashCode()+" & k2.hashCode = " + k2.hashCode());
System.out.println("(2) set`s size = " + set1.size());
//k1这个元素被成功删除
set1.remove(k1);
System.out.println("(3) set`s size = " + set1.size());
//k2这个元素没有被删除
set1.remove(k2);
System.out.println("(4) set`s size = " + set1.size());
System.out.println("(5) Does set have the k2? = " + set1.contains(k2));
}
}
执行的结果是:
**(1) sets size = 2
s size = 2
k1.equals(k2) = true
k1.hashCode = 1 & k2.hashCode = 1
(2) set
(3) sets size = 1
s size = 1
(4) set
(5) Does set have the k2? = false**
这时我根据scjp题库中的一道题,稍微修改了一下。
根据输出的结果,我的试验结果是:set没有再把重复的元素从set中删除,但是,修改完的对象,已经不是原来的那个对象了,他们之间已经失去了引用关系。至于,为何这样,我水平有限,只能先留个疑问在这里。
看自己以后有没有能力来解答。