Skip to Content
Java Generics and Collections, 2nd Edition
book

Java Generics and Collections, 2nd Edition

by Maurice Naftalin, Philip Wadler
June 2025
Intermediate to advanced
368 pages
10h 7m
English
O'Reilly Media, Inc.
Content preview from Java Generics and Collections, 2nd Edition

Chapter 15. Maps

The Map interface is the last of the major Collections Framework interfaces, and the only one that does not inherit from Collection. A Map stores key-to-value associations, or entries, in which the keys are unique. The importance of this interface lies in the fact that its implementations provide very fast—ideally, constant-time—operations to look up the value corresponding to a given key.

The Map interface overrides the equals and hashCode methods and provides definitions for them (hashCode should always be overridden when equals is overridden, as we saw in the discussion of hash tables in “Implementations”). For the purposes of these methods, a Map is considered as a Set of map entries (key-value pairs). As with the Set contract, a Map can only ever be equal to another Map, and then only if they are the same size and contain equal entries. The hash code of a Map is the sum of the hash codes of its entries. A map entry is defined by the Map.Entry interface. Two map entries are equal if both their keys and values are equal, and the hash code of a map entry is defined to be the result of applying an exclusive OR operation on the hash codes of the key and the value.

Map Interface Methods

The methods of Map can be divided according to the two ways in which a map can be seen: as a set of entries or as a lookup ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

Java Performance, 2nd Edition

Java Performance, 2nd Edition

Scott Oaks
Java in a Nutshell, 8th Edition

Java in a Nutshell, 8th Edition

Benjamin J. Evans, Jason R. Clark, David Flanagan
The Well-Grounded Java Developer, Second Edition

The Well-Grounded Java Developer, Second Edition

Jason Clark, Martijn Verburg, Benjamin Evans

Publisher Resources

ISBN: 9781098136710Errata Page