THE GENERAL BLOG

How HashSet Works Internally in Java — Step-by-Step Explanation with Example

Posted on October 19, 2025

Learn how Java’s HashSet works internally with HashMap. This guide explains how hashCode() and equals() ensure uniqueness, how elements are stored in buckets, and why HashSet provides O(1) performance for add and lookup operations.

🧩 What is a HashSet?

A HashSet in Java is a collection that stores unique elements. Under the hood, it’s actually built on top of a HashMap — yes, really!

Each element you add to a HashSet is stored as a key in an internal HashMap, and all the values are just dummy objects.

private transient HashMap<E,Object> map;
private static final Object PRESENT = new Object();

So when you do:

set.add("Alice");

it’s equivalent to:

map.put("Alice", PRESENT);

⚙️ Step-by-Step: How HashSet Works Internally

Let’s go through the life of one element being added 👇

Suppose we do:

HashSet<Person> set = new HashSet<>();
set.add(new Person("Alice", 25));

Step 1: Call hashCode()

Java first calls:

int hash = person.hashCode();

to get a numeric value — e.g. 12345.

Step 2: Find the bucket

Java calculates which bucket to store the object in:

bucketIndex = hash % numberOfBuckets;

If the number of buckets is, say, 16:

12345 % 16 = 9

So the object goes into bucket #9.

Step 3: Check for duplicates

In bucket #9:

  • If the bucket is empty → store it there.

  • If not, Java calls equals() to check if an equal object already exists.

    • If equals() returns true → it’s a duplicate, so don’t add it.
    • If equals() returns false → store it in the same bucket (linked list).

Step 4: Store the object

If unique, Java stores it in that bucket:

[9] → Alice(25)

and marks it as a key in the underlying HashMap.

🎨 3️⃣ Visual Diagram

Let’s imagine a HashSet with 8 buckets.

Initial state:
[0]
[1]
[2]
[3]
[4]
[5]
[6]
[7]

After adding some people:

[0]
[1]
[2]  → Bob(30)
[3]
[4]
[5]  → Alice(25)
[6]
[7]

Now if we add another Alice:

set.add(new Person("Alice", 25));

Steps:

  1. hashCode() = same as old Alice → goes to bucket 5
  2. equals() = true (same name and age)
  3. So HashSet doesn’t add it again.

But if hashCode is same but equals is false:

Two people with same age but different names might land in the same bucket:

[5] → Alice(25) → Alicia(25)

→ Java will store them both but keeps them distinct by checking equals().

🧠 4️⃣ Summary Table

Step What happens Which method is used
Compute hash Finds which bucket hashCode()
Check for duplicates Compares with existing items equals()
Add element Only if not found equal Uses both

🔍 5️⃣ Why it’s efficient

  • Lookup (contains()) and insert (add()) are roughly O(1) time — much faster than an ArrayList which can take O(n) for contains().
  • But only if hashCode() distributes objects evenly.


The Most Popular Blog

The best tips and tricks on managing digital documents

Understanding the concept of Encapsulation and Polymorphism in java

Encapsulation is a fundamental principle in object-oriented programming (OOP) where the internal sta...

Read More >

How to convert PDF to Text free online with no restriction ?

Converting PDF to text makes it easier to search for specific words, phrases, or keywords within the...

Read More >

How to Convert HEIF to JPEG Online Using Converteasly

Easily convert HEIF images from iPhone or iPad into JPEG for universal compatibility and sharing.

Read More >

How HashSet Works Internally in Java — Step-by-Step Explanation with Example

Understanding HashSet in Java: Internal Working, HashMap Relation, and Efficiency Explained

Read More >

How to protect your PDF file with password online ?

When sharing sensitive or confidential documents, protecting the PDF ensures that only intended reci...

Read More >

How to compress or reduce image size online using converteasly ?

Compressing images is crucial for optimizing website performance. Large image file sizes can signifi...

Read More >

Simple steps to decode Base64 to Text online using converteasly

Some APIs return data in Base64 encoded format, especially when dealing with binary data or non-text...

Read More >

How to change width and height of image online free ?

Resizing images is crucial for optimizing website performance and improving user experience.

Read More >

How to Convert HEIC to JPEG Online Using Converteasly

Easily convert HEIC images from your iPhone or iPad to universally compatible JPEG format without lo...

Read More >

Effortlessly Compare JSON Objects & Arrays with Converteasly

Are you getting frusted to compare two json data using online tools ? here is the solution for you.

Read More >

How to unlock password protected PDF online using converteasly ?

Unlocking password-protected PDFs or removing restrictions can streamline document workflows, especi...

Read More >

How to convert Rich Text Format (.rtf) file to Epub online free using converteasly ?

Educational institutions and educators can convert RTF-based textbooks, study guides, and educationa...

Read More >

How to convert ODF Formula (.odf) file to PDF online using converteasly ?

Educators can convert course materials, lecture notes, and educational resources from ODF to PDF for...

Read More >

Unlocking the Power of Java Multithreading

Multithreading is a programming technique that enables a program to execute multiple threads or flow...

Read More >

Understanding equals() and hashCode() in Java with Examples

Learn the difference between equals() and hashCode() in Java, their relationship, and why they matte...

Read More >

How to convert webp to jpg or jpeg or png online using converteasly ?

By converting WebP images to JPEG or PNG, you ensure compatibility with a broader range of devices, ...

Read More >

How to Convert AVIF Images to PDF Online Free Using Converteasly

Easily convert AVIF images into universally compatible PDF documents for sharing, printing, and arch...

Read More >

Convert AVIF images to JPEG online using Converteasly

Convert AVIF images to JPEG quickly and easily without losing quality, directly from your browser.

Read More >

Free tool to convert Excel (.xls/.xlsx) file to PDF online.

When you want to share your spreadsheet data with others who may not have Excel or who need a format...

Read More >

How to convert Docx file to Epub online free using converteasly ?

Teachers, educators, and instructional designers can convert lesson plans, textbooks, educational gu...

Read More >

How to Create and Download Your Digital Signature Securely Online

Draw your signature safely online with Converteasly — fast, free, and privacy-first.

Read More >

Convert HEIC to PDF Online Easily with Converteasly

Easily convert HEIC images from iPhones or iPads into universally compatible PDF documents without l...

Read More >

How to convert jpg or jpeg to png online using converteasly ?

Converting JPG to PNG can be useful when you want to compress an image while maintaining its quality...

Read More >

How to Remove Background of Image using converteasly

In today digital world, having images with transparent backgrounds is often a necessity for designer...

Read More >

How to rotate image left and right online using converteasly ?

Images captured with digital cameras or smartphones may sometimes have incorrect orientations due to...

Read More >

How to convert docx file to pdf online free ?

Presentations created in DOCX format might need to be shared with clients or partners. Converting th...

Read More >

How to Unescape JSON Using Converteasly

Are you dealing with escaped JSON that needs to be converted back to its original form?

Read More >

Exploring JDK 17 Features: A Comprehensive Guide

Java Development Kit (JDK) 17, released in September 2021, is the Long-Term Support (LTS) version of...

Read More >

Effortless JSON Viewing & Editing with Converteasly – Simplify Your Workflow

Are you looking for a tool to help you work with JSON data?, you might be tired of dealing with the ...

Read More >

Free tool to convert text to pdf online with no restriction

A free tool to convert one or multiple text files to PDF online, at no-cost, no-registration, and no...

Read More >

💕© 2025 converteasly.com - Made with love for the people of the internet.