Java中HashSet、TreeSet和LinkedHashSet的比较
写在前面:
嘤…嘤嘤,本菜鸡只会用C++的STL,通过前面的博文也可以看出来。我jio得非常有必要学习一下JAVA中的STL。好了,不瞎哔哔了。
说正经的:
我是站在C++的基础上来理解JAVA的Set用法的,JAVA中常用的Set方法:
函数和用法 |
---|
add( ) 向集合中添加元素 |
clear( ) 去掉集合中所有的元素 |
contains( ) 判断集合中是否包含某一个元素 |
isEmpty( ) 判断集合是否为空 |
iterator( ) 主要用于递归集合,返回一个Iterator()对象 |
remove( ) 从集合中去掉特定的对象 |
size( ) 返回集合的大小 |
Java中的set有三种:HashSet,TreeSet和LinkedHashSet。
①HashSet的输出顺序是不确定的,但是它的速度最快;
②TreeSet输出顺序是升序排列的,相当于C++中的set,个人比较喜欢这种;
③LinkedHashSet输出顺序是确定的,就是插入时的顺序。
Talk is cheap,show me the code!下面通过一段代码来比较三者的性能:
比较结果:
HashSet的输出顺序:1 99 6 23 88 58 耗时(单位:纳秒):263293
TreeSet的输出顺序:1 6 23 58 88 99 耗时(单位:纳秒):554667
LinkedHashSet的输出顺序:1 6 58 99 23 88 耗时(单位:纳秒):615202

原文链接:Java中HashSet、TreeSet和LinkedHashSet的比较
麦芽雪冷萃 版权所有,转载请注明出处。
还没有任何评论,你来说两句吧!