Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Map in Map in Guava

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>>?

like image 392
WannaKnow Avatar asked Feb 01 '13 11:02

WannaKnow


2 Answers

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 an ImmutableTable.Builder and benefit from this optimisation as well as simplify your life if the table is shared among several threads.

like image 194
assylias Avatar answered Oct 21 '22 11:10

assylias


Take a look at Guava's Table interface.

Its documentation example seems to overlap quite a bit with your use-case:

Typically, when you are trying to index on more than one key at a time, you will wind up with something like Map<FirstName, Map<LastName, Person>>, which is ugly and awkward to use. Guava provides a new collection type, Table, which supports this use case for any "row" type and "column" type.

like image 26
Henrik Aasted Sørensen Avatar answered Oct 21 '22 09:10

Henrik Aasted Sørensen