Java Set是否保持秩序?一个方法返回一个集合,假设数据是有序的,但在集合上迭代,数据是无序的。有没有更好的办法来解决这个问题?是否需要更改方法以返回Set以外的内容?
当前回答
Set接口本身没有规定任何特定的顺序。但是SortedSet可以。
其他回答
LinkedHashSet是你需要的。
只有SortedSet可以对集合进行排序
Set只是一个接口。为了保持顺序,您必须使用该接口和子接口SortedSet的特定实现,例如TreeSet或LinkedHashSet。你可以这样包装你的Set:
Set myOrderedSet = new LinkedHashSet(mySet);
因为许多成员建议使用LinkedHashSet来保留集合的顺序。 你可以使用这个实现来包装你的集合。
SortedSet实现可以用于排序顺序,但对于您的目的使用LinkedHashSet。
从医生那里,
这个实现使它的客户端免受HashSet提供的未指定的、通常是混乱的排序,而不会产生与TreeSet相关的增加的成本。它可以用来产生一个集的副本,其顺序与原始集相同,而不管原始集的实现:
来源:http://docs.oracle.com/javase/6/docs/api/java/util/LinkedHashSet.html
下面是Java中可用的标准Set实现的顺序特征的快速总结:
保持插入顺序:LinkedHashSet和CopyOnWriteArraySet(线程安全) 在TreeSet, EnumSet(特定于enum)和ConcurrentSkipListSet(线程安全)中保持项目的排序 不以任何特定的顺序保存项:
对于您的特定情况,您可以先对项进行排序,然后使用1或2中的任何一个(很可能是LinkedHashSet或TreeSet)。或者更有效地,您可以将未排序的数据添加到TreeSet,它将自动为您处理排序。
推荐文章
- set()是如何实现的?
- 使用Enum实现单例(Java)
- RabbitMQ与通道和连接之间的关系
- buildSessionFactory()配置方法在Hibernate中已弃用?
- Spring MVC -如何获得所有的请求参数在一个地图在Spring控制器?
- 如何在Java中按两个字段排序?
- 文件之间的差异。路径中的分隔符和斜杠
- 在方法参数中使用NotNull注释
- Spring MVC中处理可选参数的@RequestParam
- Tomcat:如何查找正在运行的Tomcat版本?
- “java”、“javaw”和“javaws”之间有什么区别?
- 将Date对象转换为日历对象
- 在Java中保存最后N个元素的大小有限的队列
- 如何运行一个类从Jar不是主类在其清单文件
- 使arrayList.toArray()返回更具体的类型