Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Java HashMap<String,List<String>>() Comparison

I'm wondering the best way to compare these two HashMaps. I want to verify if they are the same, and if not, what is the difference. If it matters, then I'm wondering what the 2nd one has/does not have that the first hashmap does have. I'll need to know if one has a key the other does not, as well as the Value List differences per key. I'm hoping there is a simple way to map this, but not sure. Basic Example:

    HashMap<String, List<String>> hmOne = new HashMap<String, List<String>>();
    List<String>l1 = new ArrayList<String>();

    l1.add("one");
    l1.add("two");
    l1.add("three");
    l1.add("four");
    l1.add("five");
    hmOne.put("firstkey", l1);
    l1 = new ArrayList<String>();

    l1.add("1");
    l1.add("2");
    l1.add("3");
    l1.add("4");
    l1.add("5");
    hmOne.put("secondkey", l1);

    HashMap<String, List<String>> hmTwo = new HashMap<String, List<String>>();
    List<String>l2 = new ArrayList<String>();
    l2.add("one");
    l2.add("two");
    l2.add("four");
    l2.add("five");
    hmTwo.put("firstkey", l2);
    l2 = new ArrayList<String>();

    l2.add("1");
    l2.add("3");
    l2.add("4");
    l2.add("5");
    hmTwo.put("secondkey", l2);

Thanks for any help.

like image 359
Green Avatar asked Oct 19 '11 18:10

Green


2 Answers

guava has Maps.difference(map1, map2)

like image 125
Bozho Avatar answered Oct 19 '22 11:10

Bozho


HashMap.equals will tell you if they are identical (same keys and values) but the rest you will have to roll yourself.

You will need to iterate the keyset() of one HashMap, look for it in the keySet() of the other and if found then compare the values.

Then, you will have to do the reverse, looking for keys in the second that don't exist in the first. You can probably use Set methods for this.

like image 43
Miserable Variable Avatar answered Oct 19 '22 11:10

Miserable Variable