Skip to main content

Java Exception Handling MCQ Test

  Loading…

The catch Blocks

 The `catch` blocks in Java are used to handle exceptions that occur within a `try` block. Each `catch` block specifies the type of exception it can handle, allowing you to provide different handling logic for different types of exceptions.


Syntax:


try {

    // Code that may throw an exception

} catch (ExceptionType1 ex1) {

    // Code to handle ExceptionType1

} catch (ExceptionType2 ex2) {

    // Code to handle ExceptionType2

} finally {

    // Cleanup code (optional)

}

```


Explanation:

- Each `catch` block specifies the type of exception it can handle, denoted by `ExceptionType`. If an exception of that type (or a subtype) occurs in the `try` block, the corresponding `catch` block is executed.

- You can have multiple `catch` blocks to handle different types of exceptions.

- The order of `catch` blocks is important, as Java checks them sequentially from top to bottom. It's recommended to catch subclasses before their superclasses to avoid unreachable code warnings.

- If an exception occurs that is not caught by any of the `catch` blocks in the `try` block, it propagates up the call stack to the calling method or terminates the program if unhandled.


 Example:


public class CatchBlockExample {

    public static void main(String[] args) {

        try {

            int result = 10 / 0; // This will throw ArithmeticException

            System.out.println("Result: " + result); // This line will not be executed

        } catch (ArithmeticException e) {

            System.out.println("An arithmetic exception occurred: " + e.getMessage());

        } catch (Exception e) {

            System.out.println("An exception occurred: " + e.getMessage());

        } finally {

            System.out.println("Finally block executed.");

        }

    }

}


In this example, the `try` block attempts to perform division by zero, which throws an `ArithmeticException`. The first `catch` block handles this specific type of exception. If any other type of exception occurs, it is caught by the second `catch` block, which handles exceptions of type `Exception` (the superclass of all exceptions).

Analogy:

Think of `catch` blocks as safety nets deployed along a risky journey. Each safety net is designed to catch specific types of falls or mishaps. If one safety net fails to catch you, another one is there to prevent your descent into chaos. Finally, after navigating the hazards, you reach the `finally` block, where you can assess the situation and continue on your path.

Comments

Popular posts from this blog

Passing and Returning Objects in Java Methods

Passing and Returning Objects in Java Methods In Java, objects can be passed as parameters to methods and returned from methods just like other primitive data types. This allows for flexibility and the manipulation of object state within methods. Let's explore how passing and returning objects work in Java. Passing Objects as Parameters When you pass an object as a parameter to a method, you are essentially passing a reference to that object. This means that changes made to the object inside the method will affect the original object outside the method.  Example: class Car {     String model;     Car(String model) {         this.model = model;     } } public class CarProcessor {     // Method to modify the Car object     static void modifyCar(Car car, String newModel) {         car.model = newModel;     }     public static void main(String[] args) {       ...

Why is String[] args necessary in main() method in Java?

  Why is String[] args necessary in main() method in Java? In Java, the main method serves as the entry point for the program. The correct syntax for the main method is: public static void main (String[] args) { System.out.println( "Hello, Java!" ); } 🔹 Breaking it down: public → Accessible from anywhere. static → No need to create an object of the class to run it. void → No return value. main → Special method recognized by the JVM as the starting point. String[] args → Stores command-line arguments (optional but required by JVM). Why Can't We Skip String[] args ? JVM looks for main(String[] args) When you run a Java program, the JVM searches for the main method with exactly this signature : public static void main (String[] args) If you change or remove String[] args , the JVM cannot find the correct main() method and throws a runtime error (NoSuchMethodError). Java Specification Requires It The Java Language Specification (JLS) defines that main...