I have some code with Map<String, Map<String, String>>
objects, which works (it is instantiated as a HashMap of HashMaps), but I wonder whether there is a better way to represent this data structure in Guava.
I have considered Multimap
, but while there is ListMultimap
and SetMultimap
in Guava, I have found no "MapMultimap".
I have also checked Table, which seems to be more like it, but its name is making me uncomfortable: what I have is definitely not a table but a tree. (There is no overlap between the second keys)
Is there a better Guava alternative or should I stick with Map<String, Map<String, String>>
?
Table
seems well suited for your need. But make sure you choose the proper implementation. In particular, if your second keys are all distinct (the columns in the table) the resulting table will be sparse and you should take that into account to manage memory usage.So you should avoid the ArrayTable, but can use any of the other implementations. Note that the docs mention that
ImmutableTable
has optimized implementations for sparser and denser data sets.If your
Table
is constructed at once, you can use anImmutableTable.Builder
and benefit from this optimisation as well as simplify your life if the table is shared among several threads.Take a look at Guava's
Table
interface.Its documentation example seems to overlap quite a bit with your use-case: