Monday, 31 December 2018

ITV-JAVA-Exception

1)https://www.javatpoint.com/exception-handling-in-java

2)https://www.quora.com/What-is-difference-between-a-checked-and-unchecked-exception


Unchecked: “Error” and its subclasses,”RunTimeException” and its subclasses
Checked: Every exception other than Unchecked exception
Checked Exception: These are the exceptions which may occur regularly in a program and compiler will check for those exceptions at “Compile Time” ,those exceptions are called Checked Exceptions
Example: FileNotFoundException, EndOfFileException etc.

So the compiler at compile time will check if a certain method is throwing any of the checked exceptions or not,if yes it will check whether the method is handling that exception either with “Try&Catch” or “throws”,if in case the method is not providing the handling code then compiler will throw error saying “Unreported Exception”
For example
  1. import java.io.*
  2. Class Example
  3. {
  4. public static void main(String[] args)
  5. {
  6. PrintWriter pw=new PrintWriter("xyz.txt"); //creating a new printwriter object to write in a file named "xyz.txt"
  7. pw.println("Hello World");
  8. } }
The above snippet is supposed to print “Hello World” in file named “xyz.txt”
There may be a chance of file “xyz.txt” is not present in specified directory,so the compiler will check if any handling code is provided in case file is not present
In above snippet handling code is not provided either with “Try&Catch” or “throws” so the compiler will throw error
The same example with some modification:
  1. import java.io.*
  2. Class Example
  3. {
  4. public static void main(String[] args) throws FileNotFoundException
  5. {
  6. PrintWriter pw=new PrintWriter("xyz.txt"); //creating a new printwriter object to write in a file named "xyz.txt"
  7. pw.println("Hello World");
  8. }}
In this example handling code is provided with “throws” so compiler will not throw any error.
Unchecked Exceptions:
There are some exceptions which do not occur regularly in a program,and compiler will not check for those exceptions,these kind of exceptions are called Unchecked Exceptions
Example: ArithmeticException, NullPointerException etc
For example:
  1. class Example{
  2. public static void main(String[] args){
  3. System.out.println(10/0); //Arithmetic Exception
  4. }
  5. }
The above program should throw “Arithmetic Exception” as division with “0” is not allowed
In this case the program compiles fine because compiler will not check for “Unchecked Exceptions” but the program will throw error at “Run Time” as division with “0” is illegal.
P.S: All the exceptions occurs at “Run Time” only.

writing this line because many people think that “Checked Exceptions” occurs at Compile time and “Unchecked Exceptions” occurs at Run time,which is not the case.
Q3)What is the difference between an exception and error?
An exception is an event that represents a condition from which is possible to recover, whereas error represents an external situation usually impossible to recover from.
All errors thrown by the JVM are instances of Error or one of its subclasses, the more common ones include but are not limited to:
  • OutOfMemoryError – thrown when the JVM cannot allocate more objects because it is out memory, and the garbage collector was unable to make more available
  • StackOverflowError – occurs when the stack space for a thread has run out, typically because an application recurses too deeply
  • ExceptionInInitializerError – signals that an unexpected exception occurred during the evaluation of a static initializer.
  • NoClassDefFoundError – is thrown when the classloader tries to load the definition of a class and couldn’t find it, usually because the required class files were not found in the classpath
  • UnsupportedClassVersionError – occurs when the JVM attempts to read a class file and determines that the version in the file is not supported, normally because the file was generated with a newer version of Java
Although an error can be handled with a try statement, this is not a recommended practice since there is no guarantee that the program will be able to do anything reliably after the error was thrown.

Q4. What exception will be thrown executing the following code block?

Integer[][] ints = { { 1, 2, 3 }, { null }, { 7, 8, 9 } };
System.out.println("value = " + ints[1][1].intValue());
Ans:
It throws an ArrayIndexOutOfBoundsException since we’re trying to access a position greater than the length of the array.

Q5. What is exception chaining?

Ans:
        Occurs when an exception is thrown in response to another exception. This allows us to discover the complete history of our raised problem:
1
2
3
4
5
try {
    task.readConfigFile();
} catch (FileNotFoundException ex) {
    throw new TaskException("Could not perform task", ex);
}

Q6. What is a stacktrace and how does it relate to an exception?

Ans:
       A stack trace provides the names of the classes and methods that were called, from the start of the application to the point an exception occurred.
It’s a very useful debugging tool since it enables us to determine exactly where the exception was thrown in the application and the original causes that led to it.

Q7. Can you throw any exception inside a lambda expression’s body?

When using a standard functional interface already provided by Java, you can only throw unchecked exceptions because standard functional interfaces do not have a “throws” clause in method signatures:
1
2
3
4
5
6
7
List<Integer> integers = Arrays.asList(3, 9, 7, 0, 10, 20);
integers.forEach(i -> {
    if (i == 0) {
        throw new IllegalArgumentException("Zero not allowed");
    }
    System.out.println(Math.PI / i);
});
However, if you are using a custom functional interface, throwing checked exceptions is possible:
1
2
3
4
@FunctionalInterface
public static interface CheckedFunction<T> {
    void apply(T t) throws Exception;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public void processTasks(
  List<Task> taks, CheckedFunction<Task> checkedFunction) {
    for (Task task : taks) {
        try {
            checkedFunction.apply(task);
        } catch (Exception e) {
            // ...
        }
    }
}
processTasks(taskList, t -> {
    // ...
    throw new Exception("Something happened");
});

Q13. What are the rules we need to follow when overriding a method that throws an exception?

Several rules dictate how exceptions must be declared in the context of inheritance.
When the parent class method doesn’t throw any exceptions, the child class method can’t throw any checked exception, but it may throw any unchecked.
Here’s an example code to demonstrate this:
1
2
3
4
5
6
7
8
9
10
11
class Parent {
    void doSomething() {
        // ...
    }
}
class Child extends Parent {
    void doSomething() throws IllegalArgumentException {
        // ...
    }
}
The next example will fail to compile since the overriding method throws a checked exception not declared in the overridden method:
1
2
3
4
5
6
7
8
9
10
11
class Parent {
    void doSomething() {
        // ...
    }
}
class Child extends Parent {
    void doSomething() throws IOException {
        // Compilation error
    }
}
When the parent class method throws one or more checked exceptions, the child class method can throw any unchecked exception; all, none or a subset of the declared checked exceptions, and even a greater number of these as long as they have the same scope or narrower.
Here’s an example code that successfully follows the previous rule:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
class Parent {
    void doSomething() throws IOException, ParseException {
        // ...
    }
    void doSomethingElse() throws IOException {
        // ...
    }
}
class Child extends Parent {
    void doSomething() throws IOException {
        // ...
    }
    void doSomethingElse() throws FileNotFoundException, EOFException {
        // ...
    }
}
Note that both methods respect the rule. The first throws fewer exceptions than the overridden method, and the second, even though it throws more; they’re narrower in scope.
However, if we try to throw a checked exception that the parent class method doesn’t declare or we throw one with a broader scope; we’ll get a compilation error:
1
2
3
4
5
6
7
8
9
10
11
class Parent {
    void doSomething() throws FileNotFoundException {
        // ...
    }
}
class Child extends Parent {
    void doSomething() throws IOException {
        // Compilation error
    }
}
When the parent class method has a throws clause with an unchecked exception, the child class method can throw none or any number of unchecked exceptions, even though they are not related.
Here’s an example that honors the rule:
1
2
3
4
5
6
7
8
9
10
11
12
class Parent {
    void doSomething() throws IllegalArgumentException {
        // ...
    }
}
class Child extends Parent {
    void doSomething()
      throws ArithmeticException, BufferOverflowException {
        // ...
    }
}

Q14. Will the following code compile?

1
2
3
4
void doSomething() {
    // ...
    throw new RuntimeException(new Exception("Chained Exception"));
}
Yes. When chaining exceptions, the compiler only cares about the first one in the chain and, because it detects an unchecked exception, we don’t need to add a throws clause.

Q15. Is there any way of throwing a checked exception from a method that does not have a throws clause?

Yes. We can take advantage of the type erasure performed by the compiler and make it think we are throwing an unchecked exception, when, in fact; we’re throwing a checked exception:
1
2
3
4
5
6
7
public <T extends Throwable> T sneakyThrow(Throwable ex) throws T {
    throw (T) ex;
}
public void methodWithoutThrows() {
    this.<RuntimeException>sneakyThrow(new Exception("Checked Exception"));
}
 

  1. What is Exception in Java?

    Exception is an error event that can happen during the execution of a program and disrupts it’s normal flow. Exception can arise from different kind of situations such as wrong data entered by user, hardware failure, network connection failure etc.
    Whenever any error occurs while executing a java statement, an exception object is created and then JRE tries to find exception handler to handle the exception. If suitable exception handler is found then the exception object is passed to the handler code to process the exception, known as catching the exception. If no handler is found then application throws the exception to runtime environment and JRE terminates the program.
    Java Exception handling framework is used to handle runtime errors only, compile time errors are not handled by exception handling framework.
  2. What are the Exception Handling Keywords in Java?

    There are four keywords used in java exception handling.
    1. throw: Sometimes we explicitly want to create exception object and then throw it to halt the normal processing of the program. throw keyword is used to throw exception to the runtime to handle it.
    2. throws: When we are throwing any checked exception in a method and not handling it, then we need to use throws keyword in method signature to let caller program know the exceptions that might be thrown by the method. The caller method might handle these exceptions or propagate it to it’s caller method using throws keyword. We can provide multiple exceptions in the throws clause and it can be used with main() method also.
    3. try-catch: We use try-catch block for exception handling in our code. try is the start of the block and catch is at the end of try block to handle the exceptions. We can have multiple catch blocks with a try and try-catch block can be nested also. catch block requires a parameter that should be of type Exception.
    4. finally: finally block is optional and can be used only with try-catch block. Since exception halts the process of execution, we might have some resources open that will not get closed, so we can use finally block. finally block gets executed always, whether exception occurrs or not.
  3. Explain Java Exception Hierarchy?

    Java Exceptions are hierarchical and inheritance is used to categorize different types of exceptions. Throwable is the parent class of Java Exceptions Hierarchy and it has two child objects – Error and Exception. Exceptions are further divided into checked exceptions and runtime exception.
    Errors are exceptional scenarios that are out of scope of application and it’s not possible to anticipate and recover from them, for example hardware failure, JVM crash or out of memory error.
    Checked Exceptions are exceptional scenarios that we can anticipate in a program and try to recover from it, for example FileNotFoundException. We should catch this exception and provide useful message to user and log it properly for debugging purpose. Exception is the parent class of all Checked Exceptions.
    Runtime Exceptions are caused by bad programming, for example trying to retrieve an element from the Array. We should check the length of array first before trying to retrieve the element otherwise it might throw ArrayIndexOutOfBoundException at runtime. RuntimeException is the parent class of all runtime exceptions.
    exception handling in java interview questions, exception handling interview questions, java exception interview questions
  4. What are important methods of Java Exception Class?

    Exception and all of it’s subclasses doesn’t provide any specific methods and all of the methods are defined in the base class Throwable.
    1. String getMessage() – This method returns the message String of Throwable and the message can be provided while creating the exception through it’s constructor.
    2. String getLocalizedMessage() – This method is provided so that subclasses can override it to provide locale specific message to the calling program. Throwable class implementation of this method simply use getMessage() method to return the exception message.
    3. synchronized Throwable getCause() – This method returns the cause of the exception or null id the cause is unknown.
    4. String toString() – This method returns the information about Throwable in String format, the returned String contains the name of Throwable class and localized message.
    5. void printStackTrace() – This method prints the stack trace information to the standard error stream, this method is overloaded and we can pass PrintStream or PrintWriter as argument to write the stack trace information to the file or stream.
  5. Explain Java 7 ARM Feature and multi-catch block?

    If you are catching a lot of exceptions in a single try block, you will notice that catch block code looks very ugly and mostly consists of redundant code to log the error, keeping this in mind Java 7 one of the feature was multi-catch block where we can catch multiple exceptions in a single catch block. The catch block with this feature looks like below:
    
    catch(IOException | SQLException | Exception ex){
         logger.error(ex);
         throw new MyException(ex.getMessage());
    }
    
    Most of the time, we use finally block just to close the resources and sometimes we forget to close them and get runtime exceptions when the resources are exhausted. These exceptions are hard to debug and we might need to look into each place where we are using that type of resource to make sure we are closing it. So java 7 one of the improvement was try-with-resources where we can create a resource in the try statement itself and use it inside the try-catch block. When the execution comes out of try-catch block, runtime environment automatically close these resources. Sample of try-catch block with this improvement is:
    
    try (MyResource mr = new MyResource()) {
                System.out.println("MyResource created in try-with-resources");
            } catch (Exception e) {
                e.printStackTrace();
            }
    
    Read more about this at Java 7 ARM.
  6. What is difference between Checked and Unchecked Exception in Java?

    1. Checked Exceptions should be handled in the code using try-catch block or else method should use throws keyword to let the caller know about the checked exceptions that might be thrown from the method. Unchecked Exceptions are not required to be handled in the program or to mention them in throws clause of the method.
    2. Exception is the super class of all checked exceptions whereas RuntimeException is the super class of all unchecked exceptions. Note that RuntimeException is the child class of Exception.
    3. Checked exceptions are error scenarios that requires to be handled in the code, or else you will get compile time error. For example, if you use FileReader to read a file, it throws FileNotFoundException and we must catch it in the try-catch block or throw it again to the caller method. Unchecked exceptions are mostly caused by poor programming, for example NullPointerException when invoking a method on an object reference without making sure that it’s not null. For example, I can write a method to remove all the vowels from the string. It’s the caller responsibility to make sure not to pass null string. I might change the method to handle these scenarios but ideally the caller should take care of this.
  7. What is difference between throw and throws keyword in Java?

    throws keyword is used with method signature to declare the exceptions that the method might throw whereas throw keyword is used to disrupt the flow of program and handing over the exception object to runtime to handle it.
  8. How to write custom exception in Java?

    We can extend Exception class or any of it’s subclasses to create our custom exception class. The custom exception class can have it’s own variables and methods that we can use to pass error codes or other exception related information to the exception handler.
    A simple example of custom exception is shown below.
    
    package com.journaldev.exceptions;
    
    import java.io.IOException;
    
    public class MyException extends IOException {
    
     private static final long serialVersionUID = 4664456874499611218L;
     
     private String errorCode="Unknown_Exception";
     
     public MyException(String message, String errorCode){
      super(message);
      this.errorCode=errorCode;
     }
     
     public String getErrorCode(){
      return this.errorCode;
     }
     
    
    }
    
  9. What is OutOfMemoryError in Java?

    OutOfMemoryError in Java is a subclass of java.lang.VirtualMachineError and it’s thrown by JVM when it ran out of heap memory. We can fix this error by providing more memory to run the java application through java options.
    $>java MyProgram -Xms1024m -Xmx1024m -XX:PermSize=64M -XX:MaxPermSize=256m
  10. What are different scenarios causing “Exception in thread main”?

    Some of the common main thread exception scenarios are:
    • Exception in thread main java.lang.UnsupportedClassVersionError: This exception comes when your java class is compiled from another JDK version and you are trying to run it from another java version.
    • Exception in thread main java.lang.NoClassDefFoundError: There are two variants of this exception. The first one is where you provide the class full name with .class extension. The second scenario is when Class is not found.
    • Exception in thread main java.lang.NoSuchMethodError: main: This exception comes when you are trying to run a class that doesn’t have main method.
    • Exception in thread “main” java.lang.ArithmeticException: Whenever any exception is thrown from main method, it prints the exception is console. The first part explains that exception is thrown from main method, second part prints the exception class name and then after a colon, it prints the exception message.
    Read more about these at Java Exception in Thread main.
  11. What is difference between final, finally and finalize in Java?

    final and finally are keywords in java whereas finalize is a method.
    final keyword can be used with class variables so that they can’t be reassigned, with class to avoid extending by classes and with methods to avoid overriding by subclasses, finally keyword is used with try-catch block to provide statements that will always gets executed even if some exception arises, usually finally is used to close resources. finalize() method is executed by Garbage Collector before the object is destroyed, it’s great way to make sure all the global resources are closed.
    Out of the three, only finally is related to java exception handling.
  12. What happens when exception is thrown by main method?

    When exception is thrown by main() method, Java Runtime terminates the program and print the exception message and stack trace in system console.
  13. Can we have an empty catch block?

    We can have an empty catch block but it’s the example of worst programming. We should never have empty catch block because if the exception is caught by that block, we will have no information about the exception and it wil be a nightmare to debug it. There should be at least a logging statement to log the exception details in console or log files.
  14. Provide some Java Exception Handling Best Practices?

    Some of the best practices related to Java Exception Handling are:
    • Use Specific Exceptions for ease of debugging.
    • Throw Exceptions Early (Fail-Fast) in the program.
    • Catch Exceptions late in the program, let the caller handle the exception.
    • Use Java 7 ARM feature to make sure resources are closed or use finally block to close them properly.
    • Always log exception messages for debugging purposes.
    • Use multi-catch block for cleaner close.
    • Use custom exceptions to throw single type of exception from your application API.
    • Follow naming convention, always end with Exception.
    • Document the Exceptions Thrown by a method using @throws in javadoc.
    • Exceptions are costly, so throw it only when it makes sense. Else you can catch them and provide null or empty response.
    Read more about them in detail at Java Exception Handling Best Practices.
  15. What is the problem with below programs and how do we fix it?

    In this section, we will look into some programming questions related to java exceptions.
    1. What is the problem with below program?
      
      package com.journaldev.exceptions;
      
      import java.io.FileNotFoundException;
      import java.io.IOException;
      
      public class TestException {
      
       public static void main(String[] args) {
        try {
         testExceptions();
        } catch (FileNotFoundException | IOException e) {
         e.printStackTrace();
        }
       }
       
       
       
       public static void testExceptions() throws IOException, FileNotFoundException{
        
       }
      }
      
      Above program won’t compile and you will get error message as “The exception FileNotFoundException is already caught by the alternative IOException”. This is because FileNotFoundException is subclass of IOException, there are two ways to solve this problem.
      First way is to use single catch block for both the exceptions.
      
        try {
         testExceptions();
        }catch(FileNotFoundException e){
         e.printStackTrace();
        }catch (IOException  e) {
         e.printStackTrace();
        }
      
      Another way is to remove the FileNotFoundException from multi-catch block.
      
        try {
         testExceptions();
        }catch (IOException  e) {
         e.printStackTrace();
        }
      
      You can chose any of these approach based on your catch block code.
    2. What is the problem with below program?
      
      package com.journaldev.exceptions;
      
      import java.io.FileNotFoundException;
      import java.io.IOException;
      
      import javax.xml.bind.JAXBException;
      
      public class TestException1 {
      
       public static void main(String[] args) {
         try {
          go();
         } catch (IOException e) {
          e.printStackTrace();
         } catch (FileNotFoundException e) {
          e.printStackTrace();
         } catch (JAXBException e) {
          e.printStackTrace();
         }
       }
      
       public static void go() throws IOException, JAXBException, FileNotFoundException{
        
       }
      }
      
      The program won’t compile because FileNotFoundException is subclass of IOException, so the catch block of FileNotFoundException is unreachable and you will get error message as “Unreachable catch block for FileNotFoundException. It is already handled by the catch block for IOException”.
      You need to fix the catch block order to solve this issue.
      
         try {
          go();
         } catch (FileNotFoundException e) {
          e.printStackTrace();
         } catch (IOException e) {
          e.printStackTrace();
         } catch (JAXBException e) {
          e.printStackTrace();
         }
      
      Notice that JAXBException is not related to IOException or FileNotFoundException and can be put anywhere in above catch block hierarchy.
    3. What is the problem with below program?
      
      package com.journaldev.exceptions;
      
      import java.io.IOException;
      
      import javax.xml.bind.JAXBException;
      
      public class TestException2 {
      
       public static void main(String[] args) {
        try {
         foo();
        } catch (IOException e) {
         e.printStackTrace();
        }catch(JAXBException e){
         e.printStackTrace();
        }catch(NullPointerException e){
         e.printStackTrace();
        }catch(Exception e){
         e.printStackTrace();
        }
       }
      
       public static void foo() throws IOException{
        
       }
      }
      
      The program won’t compile because JAXBException is a checked exception and foo() method should throw this exception to catch in the calling method. You will get error message as “Unreachable catch block for JAXBException. This exception is never thrown from the try statement body”.
      To solve this issue, you will have to remove the catch block of JAXBException.
      Notice that catching NullPointerException is valid because it’s an unchecked exception.
    4. What is the problem with below program?
      
      package com.journaldev.exceptions;
      
      public class TestException3 {
      
       public static void main(String[] args) {
        try{
        bar();
        }catch(NullPointerException e){
         e.printStackTrace();
        }catch(Exception e){
         e.printStackTrace();
        }
        
        foo();
       }
      
       public static void bar(){
        
       }
       
       public static void foo() throws NullPointerException{
        
       }
      }
      
      This is a trick question, there is no problem with the code and it will compile successfully. We can always catch Exception or any unchecked exception even if it’s not in the throws clause of the method.
      Similarly if a method (foo) declares unchecked exception in throws clause, it is not mandatory to handle that in the program.
    5. What is the problem with below program?
      
      package com.journaldev.exceptions;
      
      import java.io.IOException;
      
      public class TestException4 {
      
       public void start() throws IOException{  
       }
       
       public void foo() throws NullPointerException{
        
       }
      }
      
      class TestException5 extends TestException4{
       
       public void start() throws Exception{
       }
       
       public void foo() throws RuntimeException{
        
       }
      }
      
      The above program won’t compile because start() method signature is not same in subclass. To fix this issue, we can either change the method singnature in subclass to be exact same as superclass or we can remove throws clause from subclass method as shown below.
      
      @Override
       public void start(){
       }
      
    6. What is the problem with below program?
      
      package com.journaldev.exceptions;
      
      import java.io.IOException;
      
      import javax.xml.bind.JAXBException;
      
      public class TestException6 {
      
       public static void main(String[] args) {
        try {
         foo();
        } catch (IOException | JAXBException e) {
         e = new Exception("");
         e.printStackTrace();
        }catch(Exception e){
         e = new Exception("");
         e.printStackTrace();
        }
       }
      
       public static void foo() throws IOException, JAXBException{
        
       }
      }
      
      The above program won’t compile because exception object in multi-catch block is final and we can’t change it’s value. You will get compile time error as “The parameter e of a multi-catch block cannot be assigned”.
      We have to remove the assignment of “e” to new exception object to solve this error.

No comments:

Post a Comment

40 Latest Interview Questions and Answers on Spring, Spring MVC, and Spring Boot

  40 Latest Interview Questions and Answers on Spring, Spring MVC, and Spring Boot 1. What is Tight Coupling? When a class (ClassA) is depen...