首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >交换HashSet和TreeSet

交换HashSet和TreeSet
EN

Stack Overflow用户
提问于 2012-08-22 16:43:53
回答 3查看 245关注 0票数 1

可能重复: Hashset vs Treeset

你能互换使用HashSetTreeSet吗?如果我在程序中用TreeSet交换Hashset,反之亦然,那么会出现什么问题呢?我知道您需要为一个Comparable实现TreeSet

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-08-22 16:52:54

如果某些API需要Set,那么您传递的实现绝对不重要。如果它需要具体的类型(不太可能),你不能混合它们。

一般来说,它们的差异在于性能(HashSet更快),但这不应影响程序的行为和顺序。HashSet中的项目顺序是不可预测的。如果您的程序依赖于任何这样的顺序,那么它应该使用LinkedHashSetTreeSet

票数 3
EN

Stack Overflow用户

发布于 2012-08-22 17:03:28

HashSetTreeSet都是Set的,它们大多是可互换的,但请记住,TreeSet也是SortedSet,因此它的元素必须实现Comparable

票数 2
EN

Stack Overflow用户

发布于 2012-08-22 16:45:28

如果你想订购你的套装,你应该使用TreeSet。如果使用HashSet,则依赖于排序的操作将得到不可预测的结果。

另一方面,如果订单不是您所担心的,那么HashSet要比TreeSet快得多。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12077715

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档