var set = Collections.synchronizedSet(new HashSet<Integer>());
可以这样来获得一个同步的集合。
对于HashSet, for循环遍历要比迭代器遍历快。
Hashset是无序的,LinkedHashSet按插入顺序排序, TreeSet是基于compare to方法大小比较排序(元素需要实现Comparable接口)。
HashSet和LinkedHashSct判定元素重复的原则:
-判定两个元素的hashCode返回值是否相同,若不同,返回false-若两者hashCode相同,判定equals方法,若不同,返回false;否则返回true;(HashSet的元素判定规则只和hashCode、 equals这2个方法有关,和compareTo方法无关。)
这3个方法三位一体,equals ()是相同的;hashCode()是相同的;toString()也应该是相同的。重写的话应该同时重写这三个方法。
TreeSet判定元素重复的原则:
需要元素继承自Comparable接口-比较两个元素的compareTo方法