I’m thinking about filling a collection with a large amount of unique objects.
How is the cost of an insert in a Set (say HashSet) compared to an List (say ArrayList)?
My feeling is that duplicate elimination in sets might cause a slight overhead.
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
There is no “duplicate elimination” such as comparing to all existing elements. If you insert into hash set, it’s really a dictionary of items by hash code. There’s no duplicate checking unless there already are items with the same hash code. Given a reasonable (well-distributed) hash function, it’s not that bad.
As Will has noted, because of the dictionary structure
HashSetis probably a bit slower than anArrayList(unless you want to insert “between” existing elements). It also is a bit larger. I’m not sure that’s a significant difference though.