1

If i put and iterate in natural order, should I use LinkedHashMap or TreeMap? I will use a Map<int, MyObj>, and I will put them in natural order (1,2,3,...). I know about their big-O time performances, but I also know that this is a borderline use.

Can someone help me? Thanks

alb_pasqua
  • 23
  • 7

2 Answers2

2

Use a TreeMap. Not for any performance reasons, but because it can be assigned to SortedMap (or NavigableMap), and that communicates clearly your intent that the map has a defined order.

erickson
  • 257,800
  • 54
  • 385
  • 479
0
  • If you want to keep the entries in the order in which you originally insert them, use LinkedHashMap.
  • If you want the entries kept in a sorted order, use a NavigableMap, the successor to SortedMap. Java comes with two such implementations: TreeMap and ConcurrentHashMap. The latter is thread-safe.

The sorted maps by default use natural order. Optionally, you can provide a Comparator to use for sorting. This has been covered many times already on Stack Overflow, so search to learn more.

Basil Bourque
  • 262,936
  • 84
  • 758
  • 1,028