1. 作为Set元素类型的自定义类,需覆写equals, hashCode。
Sample:自定义类Person (name, gender, age), 不覆写equals, hashCode.
data:image/s3,"s3://crabby-images/1a3a0/1a3a0657aef1002ea6be05014a1e19fadae15879" alt=""
hs size不变,均为1。默认hashCode基于对象引用,所以即便修改了p1属性的值,hashset仍视为同一对象。
Override equals & hashCode之后,hs size和预期一样,每次修改之后加入,size会加1.
data:image/s3,"s3://crabby-images/0f4f7/0f4f78227c434a83930694fe8576b2c3cc337595" alt=""
因为平时项目中,pojo类大部分是自动生成的(XSD生成),equals, hashCode已经默认覆写过了,所以加入set时很少考虑这个细节问题,容易出错。
2. Set also adds a stronger contract on the behavior of the equals and hashCode operations, allowing Set instances to be compared meaningfully even if their implementation types differ. Two Set instances are equal if they contain the same elements.
两个Set包含相同的元素,则equals为true.
data:image/s3,"s3://crabby-images/1ce5b/1ce5b033860e2ebde234c5e92e41349263c22d09" alt=""
注意另外一个点:TreeSet中的元素should be comparable. 可以在实例化TreeSet的时候指定一个Comparator.
3. LinkedHashSet, which is implemented as a hash table with a linked list running through it, orders its elements based on the order in which they were inserted into the set (insertion-order).
data:image/s3,"s3://crabby-images/a9cb2/a9cb2cdf665f73ddef5ef2ef9e70fcc124a181bb" alt=""
结果依次打印0到99.
4. 注意面向接口编程。声明中使用Set而不是具体实现类,以便只需要修改构造函数就可以改变具体的实现,从而影响结果。
//conversion constructor
Collection noDups = new HashSet(c);//去重
Collection noDups = new LinkedHashSet(c);//去重,保留原序
//aggregate operations
c.stream().collect(Collectors.toSet()); // no duplicates
Set set = people.stream().map(Person::getName)
.collect(Collectors.toCollection(TreeSet::new));
网友评论