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 12. Sets

A set is a collection of items that cannot contain duplicates; adding an item that is already present in the set has no effect. The interface Set<E> has the same methods as those of Collection but it is defined separately in order to allow the contract of add (and addAll, which is defined in terms of add) to reflect this. The equals method is overridden: the Set contract states that a Set can only ever be equal to another Set, and then only if they are the same size and contain equal elements. The hashCode method is also overridden, as should always be the case when equals is overridden (see “Hash tables” in “Implementations”). The hash code of a Set is the sum of the hash codes of its elements.

Let’s see an example of set operations in action. Returning to the to-do manager example introduced in “Using the Methods of Collection”, suppose that on Monday you have free time to carry out your telephone tasks. You can make the new collection of tasks for Monday by adding all your telephone tasks to the existing Monday tasks. Let mondayTasks and phoneTasks be as declared in Example 10-1.

Using a set, you can write:

org/jgcbook/chapter12/Program_1
 Set<Task> phoneAndMondayTasks = new HashSet<>(mondayTasks); phoneAndMondayTasks.addAll(phoneTasks); assert phoneAndMondayTasks.equals(Set.of(logicCode, mikePhone, paulPhone)); ...
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