Java Language Unione, combinazione e composizione di Maps


Esempio

Usa putAll per inserire tutti i membri di una mappa in un'altra. Le chiavi già presenti nella mappa avranno i loro valori corrispondenti sovrascritti.

Map<String, Integer> numbers = new HashMap<>();
numbers.put("One", 1)
numbers.put("Three", 3)
Map<String, Integer> other_numbers = new HashMap<>();
other_numbers.put("Two", 2)
other_numbers.put("Three", 4)

numbers.putAll(other_numbers)

Questo produce il seguente mapping in numbers :

"One" -> 1
"Two" -> 2
"Three" -> 4 //old value 3 was overwritten by new value 4

Se si desidera combinare i valori anziché sovrascriverli, è possibile utilizzare Map.merge , aggiunto in Java 8, che utilizza un BiFunction fornito BiFunction per unire i valori per le chiavi duplicate. merge funziona su singole chiavi e valori, quindi dovrai utilizzare un loop o Map.forEach . Qui concateniamo stringhe per chiavi duplicate:

for (Map.Entry<String, Integer> e : other_numbers.entrySet())
    numbers.merge(e.getKey(), e.getValue(), Integer::sum);
//or instead of the above loop
other_numbers.forEach((k, v) -> numbers.merge(k, v, Integer::sum));

Se si desidera applicare il vincolo non ci sono chiavi duplicate, è possibile utilizzare una funzione di unione che genera un AssertionError :

mapA.forEach((k, v) ->
    mapB.merge(k, v, (v1, v2) ->
        {throw new AssertionError("duplicate values for key: "+k);}));

Componi Map <X, Y> e Map <Y, Z> per ottenere la mappa <X, Z>

Se si desidera comporre due mapping, è possibile farlo come segue

    Map<String, Integer> map1 = new HashMap<String, Integer>();
    map1.put("key1", 1);
    map1.put("key2", 2);
    map1.put("key3", 3);
    
    Map<Integer, Double> map2 = new HashMap<Integer, Double>();
    map2.put(1, 1.0);
    map2.put(2, 2.0);
    map2.put(3, 3.0);

    Map<String, Double> map3 = new new HashMap<String, Double>();
    map1.forEach((key,value)->map3.put(key,map2.get(value)));

Questo produce la seguente mappatura

    "key1" -> 1.0
    "key2" -> 2.0
    "key3" -> 3.0