Java教程

java学习之旅2——set

本文主要是介绍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方法

 

这篇关于java学习之旅2——set的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!