在 Java 中删除数组中重复项的最佳方法是什么?
我有一个需要删除/过滤重复项的对象数组.我打算覆盖 equals &对象元素上的hachCode,然后将它们粘贴在一个集合中......但我认为我至少应该轮询stackoverflow,看看是否有其他方法,也许是其他API的一些聪明方法?
I have an Array of Objects that need the duplicates removed/filtered. I was going to just override equals & hachCode on the Object elements, and then stick them in a Set... but I figured I should at least poll stackoverflow to see if there was another way, perhaps some clever method of some other API?
推荐答案
我同意你的方法来覆盖 hashCode()
和 equals()
并使用实现Set
.
I would agree with your approach to override hashCode()
and equals()
and use something that implements Set
.
这样做还可以让任何其他开发人员清楚地知道非重复特征是必需的.
Doing so also makes it absolutely clear to any other developers that the non-duplicate characteristic is required.
另一个原因 - 您现在可以选择最能满足您需求的实现:
Another reason - you get to choose an implementation that meets your needs best now:
- HashSet
- TreeSet
- LinkedHashSet
而且您无需更改代码即可在未来更改实现.
and you don't have to change your code to change the implementation in the future.
相关文章