Skip to main content

Observer Pattern in Java Explained with Story & Real Example (2025 Guide)

 Observer Pattern Explained: From School Bell to Order Events


🎯 Why This Pattern Matters

In interviews, design patterns often pop up, and the Observer Pattern is one of the most asked. Instead of memorizing theory, let’s connect it to a story you’ll never forget — and then translate it into practical Java code you can actually show in an interview


📖 Story Analogy — The School Bell


Think back to school days:

At 12:30 PM, the bell rings.

Students run to lunch.

Teachers close books.

The peon opens gates.


👉 The bell (Subject) doesn’t know or care who reacts. Each Observer does its own thing when notified.


That’s the Observer Pattern: one subject, many independent observers reacting differently.

🧑‍💻 Practical Java Example — Order Placed Event


Let’s switch from school to a real project example: e-commerce order placement.

When an order is placed:

Send confirmation email

Write an audit log

Update metrics


Instead of hard-coding all in the service, we publish an event. Observers (listeners) handle their part.


Minimal Code

// Event class

class OrderPlacedEvent {

    String orderId;

    OrderPlacedEvent(String orderId) { this.orderId = orderId; }

}


// Subject (Publisher)

class OrderService {

    private List<Observer> observers = new ArrayList<>();

    void addObserver(Observer o) { observers.add(o); }


    void placeOrder(String orderId) {

        System.out.println("Order placed: " + orderId);

        notifyObservers(new OrderPlacedEvent(orderId));

    }


    private void notifyObservers(OrderPlacedEvent event) {

        for (Observer o : observers) o.update(event);

    }

}


// Observer interface

interface Observer {

    void update(OrderPlacedEvent event);

}


// Observers

class EmailService implements Observer {

    public void update(OrderPlacedEvent e) {

        System.out.println("📧 Email sent for order " + e.orderId);

    }

}


class AuditLog implements Observer {

    public void update(OrderPlacedEvent e) {

        System.out.println("🧾 Audit log created for order " + e.orderId);

    }

}


// Demo

public class ObserverDemo {

    public static void main(String[] args) {

        OrderService service = new OrderService();

        service.addObserver(new EmailService());

        service.addObserver(new AuditLog());


        service.placeOrder("ORD-101");

    }

}


Output:


Order placed: ORD-101

📧 Email sent for order ORD-101

🧾 Audit log created for order ORD-101


🧠 How to Explain in an Interview

“Observer Pattern allows one subject to notify multiple observers independently.”

“In real systems, we use it for event-driven flows — e.g., when an order is placed, many services react without tight coupling.”


“In Spring Boot, this is implemented with @EventListener and ApplicationEventPublisher.”


✅ Conclusion

Story: Remember the school bell → one event, many reactions.


Practice: Show a minimal “order placed” code sample.


Interview-ready: Map it to Spring events or message queues in real projects.

Comments

Popular posts from this blog

Using Java 8 Streams to Find the Second-Highest Salary in an Employee List

To find the second-highest salary from a list of employees using Java 8 streams, you can follow these steps: Create a list of employees with their salaries. Use Java 8 streams to sort the employees by salary in descending order. Skip the first element (which is the employee with the highest salary). Get the first element of the remaining stream (which is the employee with the second-highest salary). Example code: java import java.util.ArrayList; import java.util.List; class Employee { private String name; private double salary; public Employee (String name, double salary) { this .name = name; this .salary = salary; } public double getSalary () { return salary; } } public class SecondHighestSalary { public static void main (String[] args) { List<Employee> employees = new ArrayList <>(); employees.add( new Employee ( "John" , 60000.0 )); employees.add( new Employe...

Top 20 Exception Handling Interview Questions and Answers for Experienced Java Developers

Introduction: Exception handling is a crucial aspect of Java development, ensuring robust and error-tolerant code. Experienced Java developers are expected to have a deep understanding of exception handling mechanisms. In this blog post, we'll explore the top 20 interview questions related to exception handling, accompanied by detailed answers and sample code snippets to help you prepare for your next Java interview. 1. What is an exception in Java? An exception is an event that disrupts the normal flow of a program. In Java, exceptions are objects that represent errors or abnormal situations during runtime. java try { // Code that may throw an exception } catch (ExceptionType e) { // Code to handle the exception } 2. Differentiate between checked and unchecked exceptions. Checked exceptions are checked at compile-time, and the programmer is forced to either catch them or declare that the method throws them. Unchecked exceptions, on the other hand, are not checked at ...

Java Troubleshooting: Tackling Errors and Exceptions

  Java Troubleshooting: Tackling Errors and Exceptions Head-On Welcome to our comprehensive guide to troubleshooting Java errors and exceptions! As a Java developer, encountering errors and exceptions is inevitable, but with the right knowledge and strategies, you can effectively tackle these challenges head-on. In this article, we'll delve into the top 20 Java exceptions and their solutions to empower you in your coding journey. 1. NullPointerException Issue: Null reference is being accessed. Solution: Always check for null values before accessing an object's methods or properties. Example: java String str = null ; if (str != null ) { int length = str.length(); // Check for null before accessing length } else { System.out.println( "String is null." ); } 2. ClassNotFoundException Issue: Class is not found during runtime. Solution: Ensure that the required class is in the classpath or imported correctly. Example: java try { Class.forName( ...

Subscribe to get new posts

Name

Email *

Message *