Java Set是否保持秩序?一个方法返回一个集合,假设数据是有序的,但在集合上迭代,数据是无序的。有没有更好的办法来解决这个问题?是否需要更改方法以返回Set以外的内容?
当前回答
下面是Java中可用的标准Set实现的顺序特征的快速总结:
保持插入顺序:LinkedHashSet和CopyOnWriteArraySet(线程安全) 在TreeSet, EnumSet(特定于enum)和ConcurrentSkipListSet(线程安全)中保持项目的排序 不以任何特定的顺序保存项:
对于您的特定情况,您可以先对项进行排序,然后使用1或2中的任何一个(很可能是LinkedHashSet或TreeSet)。或者更有效地,您可以将未排序的数据添加到TreeSet,它将自动为您处理排序。
其他回答
有两个不同的东西。
对集合中的元素进行排序。我们有SortedSet和类似的实现。 维护集合中的插入顺序。可以使用LinkedHashSet和CopyOnWriteArraySet(线程安全)。
Set接口不提供任何排序保证。
它的子接口SortedSet表示一个按照某种标准排序的集合。在Java 6中,有两个实现SortedSet的标准容器。它们是TreeSet和ConcurrentSkipListSet。
除了SortedSet接口,还有LinkedHashSet类。它记住元素插入到集合中的顺序,并按此顺序返回元素。
从javadoc for Set.iterator():
返回此集合中元素的迭代器。元素不按特定顺序返回(除非这个集合是某个提供保证的类的实例)。
并且,正如shuuchan已经说过的,TreeSet是Set的一个实现,它有一个保证的顺序:
元素使用它们的自然顺序进行排序,或者通过在创建set时提供的Comparator进行排序,这取决于使用哪个构造函数。
只有SortedSet可以对集合进行排序
Set只是一个接口。为了保持顺序,您必须使用该接口和子接口SortedSet的特定实现,例如TreeSet或LinkedHashSet。你可以这样包装你的Set:
Set myOrderedSet = new LinkedHashSet(mySet);
推荐文章
- 在流中使用Java 8 foreach循环移动到下一项
- 访问限制:'Application'类型不是API(必需库rt.jar的限制)
- 用Java计算两个日期之间的天数
- 如何配置slf4j-simple
- 在Jar文件中运行类
- 带参数的可运行?
- jQuery表格排序
- 我如何得到一个字符串的前n个字符而不检查大小或出界?
- 我可以在Java中设置enum起始值吗?
- Java中的回调函数
- 我如何排序一个多维数组在PHP
- c#和Java中的泛型有什么不同?和模板在c++ ?
- 在Java中,流相对于循环的优势是什么?
- Jersey在未找到InjectionManagerFactory时停止工作
- 在Java流是peek真的只是调试?