Skip to main content

πŸ’‘Checked Exceptions in Java – The Good, The Bad & The Ugly (With Code Examples & Diagrams)

πŸ“¦ Fun & Relatable Opening

Imagine your friend hands you a mystery box and says “Don’t open it without gloves.” That’s Java giving you a checked exception — it forces you to handle it before it explodes in your face. πŸ˜„

πŸ“œ What is a Checked Exception?

Checked exceptions are checked at compile time by the Java compiler.

πŸ’‘ Examples: IOException, SQLException, ClassNotFoundException



public void readFile(String path) throws IOException {

    Files.readAllLines(Paths.get(path)); // IOException is checked

}

πŸ“Š Diagram: How Checked Exceptions Work

 [Method Call]

      |

      v

 [Throws Checked Exception]

      |

      +--> try { ... } catch(...) { ... }

      |

      +--> declare in method signature with throws


πŸ›  Advantages of Checked Exceptions (With Examples)

1️⃣ Compile-time Safety



public void loadData(String fileName) throws IOException {

    Files.readAllLines(Paths.get(fileName));

}

// Caller must handle IOException

try {

    loadData("data.txt");

} catch (IOException e) {

    System.out.println("File not found, loading defaults...");

}

✅ You’re forced to think about recovery instead of letting the app crash.

2️⃣ Explicit Documentation



public void connectToDb() throws SQLException { ... }

πŸ“œ Without reading docs, you already know database connectivity may fail.

3️⃣ Encourages Recovery



try {

    connectToDb();

} catch (SQLException e) {

    retryConnection();

}

4️⃣ Better API Clarity

πŸ‘€ URL.openStream() clearly throws IOException so you know network issues are possible.


⚠️ Disadvantages of Checked Exceptions (With Examples)

1️⃣ Boilerplate Overload



try { method1(); } catch (IOException e) {}

try { method2(); } catch (SQLException e) {}

try { method3(); } catch (ClassNotFoundException e) {}

πŸ“ Your code turns into a catch block jungle.

2️⃣ Leaks Abstraction



public void processOrder() throws SQLException {

    // Directly exposing database errors to upper layers

}

πŸ•΅️ Now even your UI layer must know about SQLException — tightly coupled.

3️⃣ Encourages Lazy Wrapping



public void doSomething() throws Exception { ... }

πŸ’€ No one knows what’s actually thrown — defeats the whole purpose.

4️⃣ Pain with Lambdas/Streams

πŸ“Œ Checked exceptions don’t work smoothly inside lambdas because functional interfaces don’t declare them. This forces you to wrap or catch them inside the lambda.



// ❌ Compile error

files.forEach(file -> Files.readAllLines(file));

// ✅ Fixed

files.forEach(file -> {

    try {

        Files.readAllLines(file);

    } catch (IOException e) {

        System.out.println("Error reading file: " + file);

    }

});

5️⃣ Inflexible API Evolution

πŸ“Œ Adding a checked exception to an existing method later will break all existing callers.



// Version 1

public void read() { ... }

// Version 2

public void read() throws IOException { ... } // Now all callers must change


πŸ’‘ Try-Catch vs Throws — Your Choice

Checked Exception Found

       |

   [Your Choice]

   /           \

try-catch     throws

πŸ“œ Option 1: Using throws



public void readFile1() throws IOException {

    Files.readAllLines(Paths.get("data.txt"));

}

πŸ“Œ Passes the responsibility to the caller.

πŸ›  Option 2: Using try-catch



public void readFile2() {

    try {

        Files.readAllLines(Paths.get("data.txt"));

    } catch (IOException e) {

        System.out.println("Handled inside method: " + e.getMessage());

    }

}

πŸ“Œ Handles it right away, hiding from the caller.

Golden Rule: Catch if you can recover meaningfully, otherwise throws and let someone else decide.


πŸ˜‚ Wrapping Up

Checked exceptions are like your mom’s warnings before a trip — you can’t leave the house until you acknowledge them. πŸ˜„

What’s your take — are you Team Checked or Team Unchecked? Drop your thoughts below ⬇️

Comments

Popular posts from this blog

πŸ” Is final Really Final in Java? The Truth May Surprise You 😲

πŸ’¬ “When I was exploring what to do and what not to do in Java, one small keyword caught my eye — final . I thought it meant: locked, sealed, frozen — like my fridge when I forget to defrost it.”   But guess what? Java has its own meaning of final… and it’s not always what you expect! πŸ˜… Let’s break it down together — with code, questions, confusion, jokes, and everything in between. 🎯 The Confusing Case: You Said It's Final... Then It Changed?! 🫠 final List<String> names = new ArrayList <>(); names.add( "Anand" ); names.add( "Rahul" ); System.out.println(names); // [Anand, Rahul] 🀯 Hold on... that’s final , right?! So how on earth is it still changing ? Time to dive deeper... 🧠 Why Is It Designed Like This? Here’s the key secret: In Java, final applies to the reference , not the object it points to . Let’s decode this like a spy mission πŸ•΅️‍♂️: Imagine This: final List<String> names = new ArrayList <>(); Be...

🌟 My Journey – From Zero to Senior Java Tech Lead 🌟

 There’s one thing I truly believe… If I can become a Java developer, then anyone in the world can. πŸ’― Sounds crazy? Let me take you back. πŸ•“ Back in 2015… I had zero coding knowledge . Not just that — I had no interest in coding either. But life has its own plans. In 2016, I got a chance to move to Bangalore and joined a Java course at a training center. That’s where it all started — Every day, every session made me feel like: "Ohhh! Even I can be a developer!" That course didn’t just teach Java — it gave me confidence . πŸ§ͺ Two Life-Changing Incidents 1️⃣ The Interview That Wasn't Planned Halfway through my course, I had to urgently travel to Chennai to donate blood to a family member. After that emotional rollercoaster, I found myself reflecting on my skills and the future. The next day, as I was preparing for my move to Bangalore to complete the remaining four months of my course, I randomly thought — "Let me test my skills... let me just see...

🎒 Java Loops: Fun, Fear, and ForEach() Fails

πŸŒ€ Oops, I Looped It Again! — The Ultimate Java Loop Guide You Won't Forget “I remember this question from one of my early interviews — I was just 2 years into Java and the interviewer asked, ‘Which loop do you prefer and why?’” At first, I thought, “Duh! for-each is cleaner.” But then he grilled me with cases where it fails. 😡 That led me to explore all loop types, their powers, and their pitfalls. Let’s deep-dive into every major Java loop with examples &  real-world guidance so you'll never forget again. πŸ” Loop Type #1: Classic For Loop — “The Old Reliable” ✅ When to Use: You need an index You want to iterate in reverse You want full control over loop mechanics ✅ Good Example: List<String> names = List.of("A", "B", "C"); for (int i = 0; i < names.size(); i++) { System.out.println(i + ": " + names.get(i)); } πŸ”₯ Reverse + Removal Example: List<String> item...