KEMBAR78
Exception Handling | PDF | Class (Computer Programming) | Method (Computer Programming)
0% found this document useful (0 votes)
62 views54 pages

Exception Handling

The document discusses exception handling in Java. It defines exceptions as unwanted events that disrupt normal program flow. It describes Java's runtime stack mechanism and default exception handling process. The exception hierarchy with Throwable at the root is presented, distinguishing between exceptions and errors. Checked and unchecked exceptions are defined. The use of try-catch blocks to customize exception handling is explained, along with control flow. Finally, exception propagation and rethrowing are briefly mentioned.

Uploaded by

Raj Awatade
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
62 views54 pages

Exception Handling

The document discusses exception handling in Java. It defines exceptions as unwanted events that disrupt normal program flow. It describes Java's runtime stack mechanism and default exception handling process. The exception hierarchy with Throwable at the root is presented, distinguishing between exceptions and errors. Checked and unchecked exceptions are defined. The use of try-catch blocks to customize exception handling is explained, along with control flow. Finally, exception propagation and rethrowing are briefly mentioned.

Uploaded by

Raj Awatade
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 54

Karrasankar158@gmail.

com

Exception Handling
Introduction
1. Runtime stack mechanism
2. Default exception handling in java
3. Exception hierarchy
4. Customized exception handling by try catch
5. Control flow in try catch
6. Methods to print exception information
7. Try with multiple catch blocks
8. Finally
9. Difference between final, finally, finalize
10. Control flow in try catch finally
11. Control flow in nested try catch finally
12. Various possible combinations of try catch
finally
13. throw keyword
14. throws keyword
15. Exception handling keywords summary
16. Various possible compile time errors in exception
handling
17. Customized exceptions
18. Top-10 exceptions
19. 1.7 Version Enhansements
1. try with resources
2. multi catch block
20. Exception Propagation
21. Rethrowing an Exception

Introduction

1
Karrasankar158@gmail.com

Exception: An unwanted unexpected event that disturbs


normal flow of the program is called exception.
Example:
SleepingException
TyrePunchuredException
FileNotFoundException ...etc
• It is highly recommended to handle exceptions. The
main objective of exception handling is graceful
(normal) termination of the program.
What is the meaning of exception handling?
Exception handling doesn't mean repairing an exception.
We have to define alternative way to continue rest of the
program normally this way of "defining alternative is
nothing but exception handling".
Example: Suppose our programming requirement is to
read data from remote file locating at London at runtime if
London file is not available our program should not be
terminated abnormally.
We have to provide a local file to continue rest of the
program normally. This way of defining alternative is
nothing but exception handling.
Example:

Try
{
read data from london file
}
catch(FileNotFoundException e)
{
2
Karrasankar158@gmail.com

use local file and continue rest of the program


normally
}
}
.
.
.

Runtime stack mechanism:


For every thread JVM will create a separate stack all
method calls performed by the thread will be stored in that
stack. Each entry in the stack is called "one activation
record" (or) "stack frame".
After completing every method call JVM removes the
corresponding entry from the stack.
After completing all method calls JVM destroys the empty
stack and terminates the program normally.
Example:

class Test
{
public static void main(String[] args){
doStuff();
}
public static void doStuff(){
doMoreStuff();
}
public static void doMoreStuff(){
System.out.println("Hello");
}}
Output:
Hello

3
Karrasankar158@gmail.com

Diagram:

Default exception handling in java:


If an exception raised inside any method then the method
is responsible to create Exception object with the
following information.
1. Name of the exception.
2. Description of the exception.
3. Location of the exception.(StackTrace)
4. After creating that Exception object the method
handovers that object to the JVM.
5. JVM checks whether the method contains any
exception handling code or not. If method won't
contain any handling code then JVM terminates that
method abnormally and removes corresponding entry
form the stack.
6. JVM identifies the caller method and checks whether
the caller method contain any handling code or not. If
the caller method also does not contain handling code

4
Karrasankar158@gmail.com

then JVM terminates that caller also abnormally and


the removes corresponding entry from the stack.
7. This process will be continued until main() method
and if the main() method also doesn't contain any
exception handling code then JVM terminates main()
method and removes corresponding entry from the
stack.
8. Then JVM handovers the responsibility of exception
handling to the default exception handler.
9. Default exception handler just print exception
information to the console in the following formats
and terminates the program abnormally.
Name of exception: description
Location of exception (stack trace)
Example:

class Test
{
public static void main(String[] args){
doStuff();
}
public static void doStuff(){
doMoreStuff();
}
public static void doMoreStuff(){
System.out.println(10/0);
}}
Output:
Runtime error
Exception in thread "main"
java.lang.ArithmeticException: / by zero
at Test.doMoreStuff(Test.java:10)
at Test.doStuff(Test.java:7)
at Test.main(Test.java:4)

5
Karrasankar158@gmail.com

Diagram:

Exception hierarchy:

Throwable acts as a root for exception hierarchy.


Throwable class contains the following two child classes.

Exception:
Most of the cases exceptions are caused by our program
and these are recoverable.
6
Karrasankar158@gmail.com

Ex : If FileNotFoundException occurs we can use local


file and we can continue rest of the program execution
normally.

Error:
Most of the cases errors are not caused by our program
these are due to lack of system resources and these are non
recoverable.
Ex : If OutOfMemoryError occurs being a programmer we
can't do anything the program will be terminated
abnormally.
System Admin or Server Admin is responsible to
raise/increase heap memory.

Checked Vs Unchecked Exceptions:


• The exceptions which are checked by the compiler for
smooth execution of the program at runtime are called
checked exceptions.
1. HallTicketMissingException
2. PenNotWorkingException
3. FileNotFoundException
• The exceptions which are not checked by the compiler
are called unchecked exceptions.
1. BombBlaustException
2. ArithmeticException
3. NullPointerException
Note: RuntimeException and its child classes, Error and its
child classes are unchecked and all the remaining are
considered as checked exceptions.
Note: Whether exception is checked or unchecked

7
Karrasankar158@gmail.com

compulsory it should occur at runtime only there is no


chance of occurring any exception at compile time.
Partially checked Vs fully checked :
A checked exception is said to be fully checked if and only
if all its child classes are also checked.
Example:
1) IOException
2) InterruptedException
A checked exception is said to be partially checked if and
only if some of its child classes are unchecked.
Example:
Exception The only partially checked exceptions available
in java are:
1. Throwable.
2. Exception.
Which of the following are checked?
1. RuntimeException-----unchecked
2. Error-----unchecked
3. IOException-----fully checked
4. Exception-----partially checked
5. InterruptedException-----fully checked
6. Throwable------partially checked
7. ArithmeticException ----- unchecked
8. NullPointerException ------ unchecked
9. FileNotFoundException ----- fully checked

8
Karrasankar158@gmail.com

Diagram:

9
Karrasankar158@gmail.com

Customized exception handling by try catch:


• It is highly recommended to handle exceptions.
• In our program the code which may cause an
exception is called risky code, we have to place risky
code inside try block and the corresponding handling
code inside catch block.
Example:

Try
{
risky code
}
catch(Exception e)
{
handling code
}
Without try catch With try catch
class Test class Test{
{ public static void
public static void main(String[] args){
main(String[] args){ System.out.println("stat
System.out.println("stat ement1");
ement1"); try{
System.out.println(10/0) System.out.println(10/0)
; ;
System.out.println("stat }
ement3"); catch(ArithmeticExceptio
} n e){
} System.out.println(10/2)
output: ;
statement1 }
RE:AE:/by zero System.out.println("stat
at Test.main() ement3");

10
Karrasankar158@gmail.com

}}
Abnormal termination. Output:
statement1
5
statement3

Normal termination.

Control flow in try catch:


try{
statement1;
statement2;
statement3;
}
catch(X e) {
statement4;
}
statement5;

• Case 1: There is no exception.


1, 2, 3, 5 normal termination.
• Case 2: if an exception raised at statement 2 and
corresponding catch block matched 1, 4, 5 normal
termination.
• Case 3: if an exception raised at statement 2 but the
corresponding catch block not matched , 1 followed
by abnormal termination.
• Case 4: if an exception raised at statement 4 or
statement 5 then it's always abnormal termination of
the program.
Note:
1. Within the try block if anywhere an exception raised
then rest of the try block won't be executed even
11
Karrasankar158@gmail.com

though we handled that exception. Hence we have to


place/take only risk code inside try and length of the
try block should be as less as possible.
2. If any statement which raises an exception and it is
not part of any try block then it is always abnormal
termination of the program.
3. There may be a chance of raising an exception inside
catch and finally blocks also in addition to try block.
Various methods to print exception information:
Throwable class defines the following methods to print
exception information to the console.
This method prints exception
information in the following format.
printStackTrace(): Name of the exception: description
of exception
Stack trace
This method prints exception
information in the following format.
toString():
Name of the exception: description
of exception
This method returns only description
getMessage(): of the exception.
Description.
Example:

12
Karrasankar158@gmail.com

Note: Default exception handler internally uses


printStackTrace() method to print exception information to
the console.

Try with multiple catch blocks:


The way of handling an exception is varied from exception
to exception hence for every exception raise a separate
catch block is required that is try with multiple catch
blocks is possible and recommended to use.
Example:
try
try {
{ .
. .

13
Karrasankar158@gmail.com

. .
. .
. catch(FileNotFoundException
} e)
catch(Exception e) {
{ use local file
default handler }
} catch(ArithmeticException e)
{
perform these Arithmetic
operations
}
catch(SQLException e)
{
don't use oracle db, use
mysql db
}
catch(Exception e)
{
default handler
}

This approach is not


This approach is highly
recommended
recommended
because for any type
because for any exception raise
of Exception
we are defining a separate catch
we are using the same
block.
catch block.

• If try with multiple catch blocks presents then order of


catch blocks is very important it should be from child
to parent by mistake if we are taking from parent to
child then we will get Compile time error saying
"exception xxx has already been caught".
Example:
class Test

14
Karrasankar158@gmail.com

class Test {
{ public static void
public static void main(String[] args)
main(String[] args) {
{ try
try {
{ System.out.println(10/
System.out.println(10/0); 0);
} }
catch(Exception e) catch(ArithmeticExcept
{ ion e)
e.printStackTrace(); {
} e.printStackTrace();
catch(ArithmeticException }
e) catch(Exception e)
{ {
e.printStackTrace(); e.printStackTrace();
}}} }}}
Output: Output:
Compile time error. Compile successfully.
Test.java:13: exception
java.lang.ArithmeticExcept
ion has already
been caught
catch(ArithmeticException
e)

Finally block:
• It is never recommended to take clean up code inside
try block because there is no guarantee for the
execution of every statement inside a try.
• It is never recommended to place clean up code inside
catch block because if there is no exception then catch
block won't be executed.
• We require some place to maintain clean up code
which should be executed always irrespective of
15
Karrasankar158@gmail.com

whether exception raised or not raised and whether


handled or not handled such type of place is nothing
but finally block.
• Hence the main objective of finally block is to
maintain cleanup code.
Example:

Try
{
risky code
}
catch(x e)
{
handling code
}
finally
{
cleanup code
}
The speciality of finally block is it will be executed always
irrespective of whether the exception raised or not raised
and whether handled or not handled.
Example 1:

class Test
{
public static void main(String[] args)
{
try
{
System.out.println("try block executed");
}
catch(ArithmeticException e)
{
System.out.println("catch block executed");
}
finally

16
Karrasankar158@gmail.com

{
System.out.println("finally block executed");
}}}
Output:
Try block executed
Finally block executed
Example 2:
class Test
{
public static void main(String[] args)
{
try
{
System.out.println("try block executed");
System.out.println(10/0);
}
catch(ArithmeticException e)
{
System.out.println("catch block executed");
}
finally
{
System.out.println("finally block executed");
}}}
Output:
Try block executed
Catch block executed
Finally block executed
Example 3:
class Test
{
public static void main(String[] args)
{
try
{
System.out.println("try block executed");
System.out.println(10/0);
}
catch(NullPointerException e)
{
System.out.println("catch block executed");
17
Karrasankar158@gmail.com

}
finally
{
System.out.println("finally block executed");
}}}
Output:
Try block executed
Finally block executed
Exception in thread "main"
java.lang.ArithmeticException: / by zero
at Test.main(Test.java:8)

Return Vs Finally:
Even though return present in try or catch blocks first
finally will be executed and after that only return statement
will be considered that is finally block dominates return
statement.
Example:

class Test
{
public static void main(String[] args)
{
try
{
System.out.println("try block executed");
return;
}
catch(ArithmeticException e)
{
System.out.println("catch block executed");
}
finally
{
System.out.println("finally block executed");
}}}
Output:

18
Karrasankar158@gmail.com

Try block executed


Finally block executed
If return statement present try catch and finally blocks then
finally block return statement will be considered.
Example:

class Test
{
public static void main(String[] args)
{
System.out.println(methodOne());
}
public static int methodOne(){
try
{
System.out.println(10/0);
return 777;
}
catch(ArithmeticException e)
{
return 888;
}
finally{
return 999;
}}}
Output:
999
There is only one situation where the finally block won't
be executed is whenever we are
using System.exit(0)method.
Then JVM itself will be shutdown , in this case finally
block won't be executed.
i.e., System.exit(0); dominates finally block.
Example:
class Test
{
public static void main(String[] args)
{

19
Karrasankar158@gmail.com

try
{
System.out.println("try");
System.exit(0);
}
catch(ArithmeticException e)
{
System.out.println("catch block executed");
}
finally
{
System.out.println("finally block executed");
}}}
Output:
Try

Note :
System.exit(0);
insteadof zero, we can take any integer value
zero means normal termination , non-zero means abnormal
termination
this status code internally used by JVM, whether it is zero
or non-zero there is no change in the result and effect is
same
Difference between final, finally, and finalize:
Final:
• Final is the modifier applicable for class, methods and
variables.
• If a class declared as the final then child class creation
is not possible.
• If a method declared as the final then overriding of
that method is not possible.

20
Karrasankar158@gmail.com

• If a variable declared as the final then reassignment is


not possible.
Finally:
• It is the block always associated with try catch to
maintain clean up code which should be executed
always irrespective of whether exception raised or not
raised and whether handled or not handled.
Finalize:
• It is a method which should be called by garbage
collector always just before destroying an object to
perform cleanup activities.
Note:
To maintain clean up code faunally block is recommended
over finalize() method because we can't expect exact
behavior of GC.
Control flow in try catch finally:
Example:
class Test
{
public static void main(String[] args){
try{
System.out.println("statement1");
System.out.println("statement2");
System.out.println("statement3");
}
catch(Exception e){
System.out.println("statement4");
}
finally

21
Karrasankar158@gmail.com

{
System.out.println("statement5");
}
System.out.println("statement6");
}
}

▪ Case 1: If there is no exception. 1, 2, 3, 5, 6 normal


termination.
▪ Case 2: if an exception raised at statement 2 and
corresponding catch block matched. 1,4,5,6 normal
terminations.
▪ Case 3: if an exception raised at statement 2 and
corresponding catch block is not matched. 1,5
abnormal termination.
▪ Case 4: if an exception raised at statement 4 then it's
always abnormal termination but before the finally
block will be executed.
▪ Case 5: if an exception raised at statement 5 or
statement 6 its always abnormal termination.

Control flow in nested try catch finally:


Example:
class Test
{
public static void main(String[] args){
try{
System.out.println("statement1");
System.out.println("statement2");
System.out.println("statement3");
try{
System.out.println("statement4");
System.out.println("statement5");
System.out.println("statement6");
}
catch(ArithmeticException e){

22
Karrasankar158@gmail.com

System.out.println("statement7");
}
finally
{
System.out.println("statement8");
}
System.out.println("statement9");
}
catch(Exception e)
{
System.out.println("statement10");
}
finally
{
System.out.println("statement11");
}
System.out.println("statement12");
}
}

▪ Case 1: if there is no exception. 1, 2, 3, 4, 5, 6, 8, 9,


11, 12 normal termination.
▪ Case 2: if an exception raised at statement 2 and
corresponding catch block matched 1,10,11,12 normal
terminations.
▪ Case 3: if an exception raised at statement 2 and
corresponding catch block is not matched 1, 11
abnormal termination.
▪ Case 4: if an exception raised at statement 5 and
corresponding inner catch has matched 1, 2, 3, 4, 7, 8,
9, 11, 12 normal termination.
▪ Case 5: if an exception raised at statement 5 and inner
catch has not matched but outer catch block has
matched. 1, 2, 3, 4, 8, 10, 11, 12 normal termination.

23
Karrasankar158@gmail.com

▪ Case 6: if an exception raised at statement 5 and both


inner and outer catch blocks are not matched. 1, 2, 3,
4, 8, 11 abnormal termination.
▪ Case 7: if an exception raised at statement 7 and the
corresponding catch block matched 1, 2, 3, 4, 5, 6, 8,
10, 11, 12 normal termination.
▪ Case 8: if an exception raised at statement 7 and the
corresponding catch block not matched 1, 2, 3, 4, 5, 6,
8, 11 abnormal terminations.
▪ Case 9: if an exception raised at statement 8 and the
corresponding catch block has matched 1, 2, 3, 4, 5, 6,
7, 10, 11,12 normal termination.
▪ Case 10: if an exception raised at statement 8 and the
corresponding catch block not matched 1, 2, 3, 4, 5, 6,
7, 11 abnormal terminations.
▪ Case 11: if an exception raised at statement 9 and
corresponding catch block matched 1, 2, 3, 4, 5, 6, 7,
8,10,11,12 normal termination.
▪ Case 12: if an exception raised at statement 9 and
corresponding catch block not matched 1, 2, 3, 4, 5, 6,
7, 8, 11 abnormal termination.
▪ Case 13: if an exception raised at statement 10 is
always abnormal termination but before that finally
block 11 will be executed.
▪ Case 14: if an exception raised at statement 11 or 12
is always abnormal termination.
Note: if we are not entering into the try block then the
finally block won't be executed. Once we entered into the
try block without executing finally block we can't come
out.

24
Karrasankar158@gmail.com

We can take try-catch inside try i.e., nested try-catch is


possible
The most specific exceptions can be handled by using
inner try-catch and generalized exceptions can be handle
by using outer try-catch.
Example:
class Test
{
public static void main(String[] args){
try{
System.out.println(10/0);
}
catch(ArithmeticException e)
{
System.out.println(10/0);
}
finally{
String s=null;
System.out.println(s.length());
}}}

output :
RE:NullPointerException
Note: Default exception handler can handle only one
exception at a time and that is the most recently raised
exception.
Various possible combinations of try catch finally:
1. Whenever we are writing try block compulsory we
should write either catch or finally.
i.e., try without catch or finally is invalid.
2. Whenever we are writing catch block compulsory we
should write try.
i.e., catch without try is invalid.

25
Karrasankar158@gmail.com

3. Whenever we are writing finally block compulsory we


should write try.
i.e., finally without try is invalid.
4. In try-catch-finally order is important.
5. With in the try-catch -finally blocks we can take try-
catch-finally.
i.e., nesting of try-catch-finally is possible.
6. For try-catch-finally blocks curly braces are
mandatory.
Example 1:
class Test1{
public static void main(String[] args){
try
{}
catch(ArithmeticException e)
{}
}}
Output:
Compile and running successfully.
Example 2:
class Test1{
public static void main(String[] args){
try
{}
catch(ArithmeticException e)
{}
catch(NullPointerException e)
{}
}
}
Output:
Compile and running successfully.
Example 3:
class Test1{
public static void main(String[] args){
try
{}

26
Karrasankar158@gmail.com

catch(ArithmeticException e)
{}
catch(ArithmeticException e)
{}
}
}
Output:
Compile time error.
Test1.java:7: exception
java.lang.ArithmeticException
has
already been caught
catch(ArithmeticException e)
Example 4:
class Test1{
public static void main(String[] args){
try
{}
}
}
Output:
Compile time error
Test1.java:3: 'try' without 'catch' or 'finally'
try
Example 5:

class Test1{
public static void main(String[] args){
catch(Exception e)
{}
}
}
Output:
Compile time error.
Test1.java:3: 'catch' without 'try'
catch(Exception e)
Example 6:
class Test1{
public static void main(String[] args){
try
{}
27
Karrasankar158@gmail.com

System.out.println("hello");
catch(Exception e)
{}
}
}
Output:
Compile time error.
Test1.java:3: 'try' without 'catch' or 'finally'
Try
Example 7:
class Test1{
public static void main(String[] args){
try
{}
catch(Exception e)
{}
finally
{}
}
}
Output:
Compile and running successfully.
Example 8:
class Test1{
public static void main(String[] args){
try
{}
finally
{}
}
}
Output:
Compile and running successfully.
Example 9:
class Test1{
public static void main(String[] args){
try
{}
finally
{}
finally
28
Karrasankar158@gmail.com

{}
}
}
Output:
Compile time error.
Test1.java:7: 'finally' without 'try'
Finally
Example 10:
class Test1{
public static void main(String[] args){
try
{}
catch(Exception e)
{}
System.out.println("hello");
finally
{}
}
}
Output:
Compile time error.
Test1.java:8: 'finally' without 'try'
Finally
Example 11:
class Test1{
public static void main(String[] args){
try
{}
finally
{}
catch(Exception e)
{}
}
}
Output:
Compile time error.
Test1.java:7: 'catch' without 'try'
catch(Exception e)
Example 12:
class Test1{
public static void main(String[] args){
29
Karrasankar158@gmail.com

finally
{}
}
}
Output:
Test1.java:3: 'finally' without 'try'
Finally
Example 13:
class Test1{
public static void main(String[] args){
try
{ try{}
catch(Exception e){}
}
catch(Exception e)
{}
}
}
Output:
Compile and running successfully.
Example 14:
class Test1{
public static void main(String[] args){
try
{ }
catch(Exception e)
{
try{}
finally{}
}
}
}
Output:
Compile and running successfully.
Example 15:
class Test1{
public static void main(String[] args){
try
{ }
catch(Exception e)
{
30
Karrasankar158@gmail.com

try{}
catch(Exception e){}
}
finally{
finally{}
}
}
}
Output:
Compile time error.
Test1.java:11: 'finally' without 'try'
finally{}

Example 16:
class Test1{
public static void main(String[] args){
finally{}
try{ }
catch(Exception e){}
}
}
Output:
Compile time error.
Test1.java:3: 'finally' without 'try'
finally{}
Example 17:
class Test1{
public static void main(String[] args){
try{ }
catch(Exception e){}
finally
{
try{}
catch(Exception e){}
finally{}
}
}
}
Output:
Compile and running successfully.

31
Karrasankar158@gmail.com

Throw statement:
Sometimes we can create Exception object explicitly and
we can hand over to the JVM manually by using throw
keyword.
Example:

The result of following 2 programs is exactly same.


class Test class Test
{ {
public static void public static void
main(String[] args){ main(String[] args){
System.out.println(10/0); throw new
}} ArithmeticException("/
by zero");
In this case creation of }}
ArithmeticException object In this case we are
and handover to the jvm will creating exception object
be performed automatically by explicitly and handover to
the main() method. the JVM manually.

Note: In general we can use throw keyword for customized


exceptions but not for predefined exceptions.

32
Karrasankar158@gmail.com

Case 1:
throw e;
If e refers null then we will get NullPointerException.
Example:
class Test3
{ class Test3
static {
ArithmeticException static
e=new ArithmeticException e;
public static void
ArithmeticException(); main(String[] args){
public static void throw e;
main(String[] args){ }
throw e; }
} Output:
} Exception in thread
Output: "main"
Runtime exception:
Exception in thread java.lang.NullPointerExc
"main" eption
at
java.lang.ArithmeticExce Test3.main(Test3.java:5)
ption

Case 2:
After throw statement we can't take any statement directly
otherwise we will get compile time error saying
unreachable statement.
Example:
class Test3 class Test3
{ {
public static void public static void
main(String[] args){ main(String[] args){
System.out.println(10/0); throw new
System.out.println("hello ArithmeticException("/
"); by zero");

33
Karrasankar158@gmail.com

} System.out.println("hel
} lo");
Output: }
Runtime error: Exception }
in thread "main" Output:
Compile time error.
java.lang.ArithmeticExcep Test3.java:5:
tion: / by zero unreachable statement
at System.out.println("hel
Test3.main(Test3.java:4) lo");

Case 3:
We can use throw keyword only for Throwable types
otherwise we will get compile time error saying
incomputable types.
Example:
class Test3
{ class Test3 extends
public static void RuntimeException
main(String[] args){ {
throw new Test3(); public static void
} main(String[] args){
}Output: throw new Test3();
Compile time error. }
Test3.java:4: }
incompatible types Output:
found : Test3 Runtime error: Exception in
required: thread "main" Test3
java.lang.Throwable at
throw new Test3(); Test3.main(Test3.java:4)

Throws statement:
In our program if there is any chance of raising checked
exception compulsory we should handle either by try catch
or by throws keyword otherwise the code won't compile.

34
Karrasankar158@gmail.com

Example:

import java.io.*;
class Test3
{
public static void main(String[] args){
PrinterWriter out=new PrintWriter("abc.txt");
out.println("hello");
}
}

CE :
Unreported exception
java.io.FileNotFoundException;
must be caught or declared to be thrown.
Example:
class Test3
{
public static void main(String[] args){
Thread.sleep(5000);
}
}

Unreported exception
java.lang.InterruptedException;
must be caught or declared to be thrown.
We can handle this compile time error by using the
following 2 ways.
Example:
By using throws
By using try catch
keyword
class Test3 We can use throws
{ keyword to delicate the
public static void
main(String[] args){ responsibility of exception
try{ handling to the caller
Thread.sleep(5000); method. Then caller
35
Karrasankar158@gmail.com

} method is responsible to
catch(InterruptedException
e){} handle that exception.
} class Test3
} {
Output: public static void
Compile and running main(String[]
successfully args)throws

InterruptedException{
Thread.sleep(5000);
}
}
Output:
Compile and running
successfully

Note :
• Hence the main objective of "throws" keyword is to
delicate the responsibility of exception handling to the
caller method.
• "throws" keyword required only checked exceptions.
Usage of throws for unchecked exception there is no
use.
• "throws" keyword required only to convenes
complier. Usage of throws keyword doesn't prevent
abnormal termination of the program.
Hence recommended to use try-catch over throws
keyword.
Example:
class Test
{
public static void main(String[] args)throws
InterruptedException{
doStuff();

36
Karrasankar158@gmail.com

}
public static void doStuff()throws
InterruptedException{
doMoreStuff();
}
public static void doMoreStuff()throws
InterruptedException{
Thread.sleep(5000);
}
}
Output:
Compile and running successfully.
In the above program if we are removing at least one
throws keyword then the program won't compile.
Case 1:
we can use throws keyword only for Throwable types
otherwise we will get compile time error saying
incompatible types.
Example:
class Test3{
public static void
main(String[] args) class Test3 extends
RuntimeException{
throws Test3 public static void
{} main(String[] args)
}
Output: throws Test3
Compile time error {}
Test3.java:2: }
incompatible types Output:
found : Test3 Compile and running
required: successfully.
java.lang.Throwable
public static void
main(String[] args)

37
Karrasankar158@gmail.com

throws Test3

Case 2: Example:
class Test3{
public static void class Test3{
main(String[] args){ public static void
throw new Exception(); main(String[] args){
} throw new Error();
} }
Output: }
Compile time error. Output:
Test3.java:3: Runtime error
unreported exception Exception in thread "main"
java.lang.Error
java.lang.Exception; at
must be caught or Test3.main(Test3.java:3)
declared to be thrown

Case 3:
In our program with in the try block, if there is no chance
of rising an exception then we can't right catch block for
that exception otherwise we will get compile time error
saying exception XXX is never thrown in body of
corresponding try statement. But this rule is applicable
only for fully checked exception.
Example:

38
Karrasankar158@gmail.com

Case 4:
We can use throws keyword only for constructors and
methods but not for classes.
39
Karrasankar158@gmail.com

Example:

Exception handling keywords summary:


1. try: To maintain risky code.
2. catch: To maintain handling code.
3. finally: To maintain cleanup code.
4. throw: To handover our created exception object to
the JVM manually.
5. throws: To delegate responsibility of exception
handling to the caller method.
Various possible compile time errors in exception
handling:
1. Exception XXX has already been caught.
2. Unreported exception XXX must be caught or
declared to be thrown.
3. Exception XXX is never thrown in body of
corresponding try statement.
40
Karrasankar158@gmail.com

4. Try without catch or finally.


5. Catch without try.
6. Finally without try.
7. Incompatible types.
8. Found:test
9. Requried:java.lang.Throwable;
10. Unreachable statement.
Customized Exceptions (User defined
Exceptions):
Sometimes we can create our own exception to meet our
programming requirements. Such type of exceptions are
called customized exceptions (user defined exceptions).
Example:
1. InSufficientFundsException
2. TooYoungException
3. TooOldException
Program:
class TooYoungException extends RuntimeException
{
TooYoungException(String s)
{
super(s);
}
}
class TooOldException extends RuntimeException
{
TooOldException(String s)
{
super(s);
}
}
class CustomizedExceptionDemo

41
Karrasankar158@gmail.com

{
public static void main(String[] args){
int age=Integer.parseInt(args[0]);
if(age>60)
{
throw new TooYoungException("please wait some more
time.... u will get best match");
}
else if(age<18)
{
throw new TooOldException("u r age already
crossed....no chance of getting married");
}
else
{
System.out.println("you will get match details
soon by e-mail");
}}}

Output:

1)E:\scjp>java CustomizedExceptionDemo 61
Exception in thread "main" TooYoungException:
please wait some more time.... u will get best
match
at
CustomizedExceptionDemo.main(CustomizedExceptionDe
mo.java:21)

2)E:\scjp>java CustomizedExceptionDemo 27
You will get match details soon by e-mail

3)E:\scjp>java CustomizedExceptionDemo 9
Exception in thread "main" TooOldException:
u r age already crossed....no chance of getting
married
at
CustomizedExceptionDemo.main(CustomizedExceptionDe
mo.java:25)
42
Karrasankar158@gmail.com

Note: It is highly recommended to maintain our


customized exceptions as unchecked by extending
RuntimeException.
We can catch any Throwable type including Errors also.
• Questions and answer
• Interview Question
• Alternatives
• Biology questions and answers
• Not Available
• Calls
• Activations
• Arithmetic
• Auto mechanic books
• Cases
• Questions and answer
• Interview Question
• Alternatives
• Biology questions and answers
• Not Available
• Calls
• Activations
• Arithmetic

Example:

Top-10 Exceptions:
Exceptions are divided into two types.
They are:
1) JVM Exceptions:
2) Programatic exceptions:

43
Karrasankar158@gmail.com

JVM Exceptions:
The exceptions which are raised automatically by the jvm
whenever a particular event occurs.
Example:
1) ArrayIndexOutOfBoundsException(AIOOBE)
2) NullPointerException (NPE).
Programatic Exceptions:
The exceptions which are raised explicitly by the
programmer (or) by the API developer are called
programatic exceptions.
Example: 1) IllegalArgumentException(IAE).
Top 10 Exceptions :
1. ArrayIndexOutOfBoundsException:
It is the child class of RuntimeException and hence it
is unchecked. Raised automatically by the JVM
whenever we are trying to access array element with
out of range index. Example:
2. class Test{
3. public static void main(String[] args){
4. int[] x=new int[10];
5. System.out.println(x[0]);//valid
6. System.out.println(x[100]);//AIOOBE
7. System.out.println(x[-100]);//AIOOBE
8. }
9. }
10. NullPointerException:
It is the child class of RuntimeException and hence it

44
Karrasankar158@gmail.com

is unchecked. Raised automatically by the JVM,


whenever we are trying to call any method on null.
11. Example:
12. class Test{
13. public static void main(String[] args){
14. String s=null;
15. System.out.println(s.length()); //R.E:
NullPointerException
16. }
17. }
18. StackOverFlowError:
It is the child class of Error and hence it is unchecked.
Whenever we are trying to invoke recursive method
call JVM will raise StackOverFloeError
automatically.
19. Example:
20. class Test
21. {
22. public static void methodOne()
23. {
24. methodTwo();
25. }
26. public static void methodTwo()
27. {
28. methodOne();
29. }
30. public static void main(String[] args)
31. {
32. methodOne();
33. }
34. }
35. Output:
36. Run time error: StackOverFloeError
37. NoClassDefFound:
It is the child class of Error and hence it is unchecked.
JVM will raise this error automatically whenever it is
unable to find required .class file. Example: java

45
Karrasankar158@gmail.com

Test If Test.class is not available. Then we will get


NoClassDefFound error.
38. ClassCastException:
It is the child class of RuntimeException and hence it
is unchecked. Raised automatically by the JVM
whenever we are trying to type cast parent object to
child type.
Example:

39. ExceptionInInitializerError:
It is the child class of Error and it is unchecked.
Raised automatically by the JVM, if any exception
occurs while performing static variable initialization
and static block execution.
40. Example 1:
41. class Test{
42. static int i=10/0;
43. }
44. Output:
45. Runtime exception:
46. Exception in thread "main"
java.lang.ExceptionInInitializerError
47. Example 2:

46
Karrasankar158@gmail.com

48. class Test{


49. static {
50. String s=null;
51. System.out.println(s.length());
52. }}
53. Output:
54. Runtime exception:
55. Exception in thread "main"
java.lang.ExceptionInInitializerError
56. IllegalArgumentException:
It is the child class of RuntimeException and hence it
is unchecked. Raised explicitly by the programmer
(or) by the API developer to indicate that a method
has been invoked with inappropriate argument.

Example:
class Test{
public static void main(String[] args){
Thread t=new Thread();
t.setPriority(10);//valid
t.setPriority(100);//invalid
}}
Output:
Runtime exception
Exception in thread "main"
java.lang.IllegalArgumentException.

57. NumberFormatException:
It is the child class of IllegalArgumentException and
hence is unchecked. Raised explicitly by the
programmer or by the API developer to indicate that
we are attempting to convert string to the number. But
the string is not properly formatted.
Example:

47
Karrasankar158@gmail.com

class Test{
public static void main(String[] args){
int i=Integer.parseInt("10");
int j=Integer.parseInt("ten");
}}
Output:
Runtime Exception
Exception in thread "main"
java.lang.NumberFormatException: For input
string: "ten"

58. IllegalStateException:
It is the child class of RuntimeException and hence it
is unchecked. Raised explicitly by the programmer or
by the API developer to indicate that a method has
been invoked at inappropriate time.
Example:
Once session expires we can't call any method on the
session object otherwise we will get
IllegalStateException
HttpSession session=req.getSession();
System.out.println(session.getId());
session.invalidate();
System.out.println(session.getId()); //
illgalstateException

59. AssertionError:
It is the child class of Error and hence it is unchecked.
Raised explicitly by the programmer or by API
developer to indicate that Assert statement fails.
Example:
assert(false);
48
Karrasankar158@gmail.com

Exception/Error Raised by
1. AIOOBE
2. NPE(NullPointerException) Raised
3. StackOverFlowError automatically by
4. NoClassDefFoundError JVM(JVM
5. CCE(ClassCastException) Exceptions)
6. ExceptionInInitializerError

Raised explicitly
1. IAE(IllegalArgumentException) either by
2. NFE(NumberFormatException) programmer or by
3. ISE(IllegalStateException) API developer
4. AE(AssertionError) (Programatic
Exceptions).

1.7 Version Enhansements :


As part of 1.7 version enhansements in Exception
Handling the following 2 concepts introduced
1. try with resources
2. multi catch block
try with resources
Untill 1.5 version it is highly recommended to write finally
block to close all resources which are open as part of try
block.
BufferedReader br=null;
try{
br=new BufferedReader(new FileReader("abc.txt"));
//use br based on our requirements
}
catch(IOException e) {

49
Karrasankar158@gmail.com

// handling code
}
finally {
if(br != null)
br.close();
}

problems in this approach :


• Compulsory programmer is required to close all
opned resources with increases the complexity of the
programming
• Compulsory we should write finally block explicity
which increases length of the code and reviews
readability.
To overcome these problems Sun People introduced
"try with resources" in 1.7 version.
The main advantage of "try with resources" is
the resources which are opened as part of try block will be
closed automatically
Once the control reaches end of the try block either
normally or abnormally and hence we are not required to
close explicitly

due to the complexity of programming will be reduced, it


is not required to write finally block explicitly and hence
length of the code will be reduced and readability will be
improved.

try(BufferedReader br=new BufferedReader(new


FileReader("abc.txt")))
{

50
Karrasankar158@gmail.com

use be based on our requirement, br will be


closed automatically ,
Onec control reaches end of try either normally
or abnormally and we are not required to close
explicitly
}
catch(IOException e) {
// handling code
}

We can declare any no of resources but all these resources


should be seperated with ;(semicolon)
try(R1 ; R2 ; R3)
{
-------------
-------------
}

All resources should be auto closable resources , a


resource is said to be auto closable if and only if the
corresponding class implements
the java.lang.AutoClosable interface either directly or
indirectly.

All resource reference variables are implicitly final and


hence we can't perform reassignment with in the try block.
try(BufferedReader br=new BufferedReader(new
FileReader("abc.txt"))) ;
{
br=new BufferedReader(new
FileReader("abc.txt"));
}

output :
CE : Can't reassign a value to final variable br

51
Karrasankar158@gmail.com

Untill 1.6 version try should be followed by either catch or


finally but 1.7 version we can take only try with resource
without catch or finally
try(R)
{ //valid
}
The main advantage of "try with resources" is finally block
will become dummy because we are not required to close
resources of explicitly.
Multi catch block :
Eventhough Multiple Exceptions having same handling
code we have to write a seperate catch block for every
exceptions, it increases length of the code and reviews
readability
try{
-----------------
-----------------
}
catch(ArithmeticException e) {
e.printStackTrace();
}
catch(NullPointerException e) {
e.printStackTrace();
}
catch(ClassCastException e) {
System.out.println(e.getMessage());
}
catch(IOException e) {
System.out.println(e.getMessage());
}
To overcome this problem Sun People introduced "Multi
catch block" concept in 1.7 version.

The main advantage of multi catch block is we can write a

52
Karrasankar158@gmail.com

single catch block , which can handle multiple different


exceptions
try{
-----------------
-----------------
}
catch(ArithmeticException | NullPointerException
e) {
e.printStackTrace();
}
catch(ClassCastException | IOException e) {
System.out.println(e.getMessage());
}
In multi catch block, there should not be any relation
between Exception types(either child to parent Or parent to
child Or same type , otherwise we will get Compile time
error )

Example:

Exception Propagation :

53
Karrasankar158@gmail.com

With in a method if an exception raised and if that method


doesn't handle that exception then Exception object will be
propagated to the caller then caller method is responsible
to handle that exceptions. This process is called Exception
Propagation.
Rethrowing an Exception :
To convert the one exception type to another exception
type , we can use rethrowing exception concept.
class Test
{
public static void main(String[] args){
try {
System.out.println(10/0);
}
catch(ArithmeticException e) {
throw new NullPointerException();
}
}
}
output:
RE:NPE

54

You might also like