Logo

Programming-Idioms

  • Haskell
  • Ruby
  • Perl

Idiom #334 Combine 2 maps

Create the new map c containing all of the (key, value) entries of the two maps a and b.

Explain what happens for keys existing in both a and b.

%c = (%a, %b);

Hash %c is assigned all the key-value pairs of %a then all the pairs of %b. The values of any duplicate keys in %b will overwrite those of %a.
c = a.merge(b)

Each duplicate-key entry’s value overwrites the previous value, unless a given block specifies other behavior.
final c = {...a, ...b};

Spread and flatten the entries of maps a and b to construct a new copy as c. Duplicate keys will favor b over a.

New implementation...
< >
programming-idioms.org