java学习之旅2——set

 var set = Collections.synchronizedSet(new HashSet<Integer>());

可以这样来获得一个同步的集合。

 

 

对于HashSet, for循环遍历要比迭代器遍历快。

 

Hashset是无序的,LinkedHashSet按插入顺序排序, TreeSet是基于compare to方法大小比较排序(元素需要实现Comparable接口)。


HashSet和LinkedHashSct判定元素重复的原则:

-判定两个元素的hashCode返回值是否相同,若不同,返回false-若两者hashCode相同,判定equals方法,若不同,返回false;否则返回true;(HashSet的元素判定规则只和hashCodeequals这2个方法有关,和compareTo方法无关。)

这3个方法三位一体,equals ()是相同的;hashCode()是相同的;toString()也应该是相同的。重写的话应该同时重写这三个方法。

 

TreeSet判定元素重复的原则:

需要元素继承自Comparable接口-比较两个元素的compareTo方法

 

上一篇:HashMap相关知识回顾


下一篇:WPF MaterialDesign 开源免费UI组件的介绍和简单使用