Java Inheritance Guide for CSE Students
Java Inheritance Guide for CSE Students
JAVA Programming Dept of CSE, VVIT Page 53 JAVA Programming Dept of CSE, VVIT Page 54
UNIT II Inheritance UNIT II Inheritance
Single Inheritance: Simple Inheritance is also called as single Inheritance. Here one subclass is Interface: An interface is a class containing a group of constants and method declarations that does
deriving from one super class. not provide implementation. In essence, an interface allows you to specify what a class must do, but
not how to do.
A B
import java.io.*; {
class A class Inh return-type method-name1(parameter-list);
{ {
void display() public static void main(String args[]) return-type method-name2(parameter-list);
{ { type varname1 = value;
B b=new B();
b.display(); type varname2 = value;
} // ...
} }
class B extends A } return-type method-nameN(parameter-list);
{ type varnameN = value;
void display() Output:
{ D:\>javac Inh.java }
System.out.println("hello"); D:\>java Inh
hello By default all the methods in an interface must be abstract and public. If we do not mention
}
} these keywords the JVM will treat all these methods as public and abstract implicitly.
All the constants are treated as public, final and static.
Multiple Inheritance: Deriving one subclass from more than one super classes is called multiple
Example:
inheritance. public void fly()
INTERFACE1 INTERFACE2 interface Animal {
{ System.out.println("birds fly in air");
A B }
public abstract void moves();
}
public static void main(String args[])
(Animal) (Bird) interface Bird {
{ InterfaceDemo2 id=new InterfaceDemo2();
IMPLEMENTS void fly(); id.moves();
} id.fly();
SUBCLASS (InterfaceDemo2) }
public class InterfaceDemo2 implements }
In multiple inheritance, sub class is derived from multiple super classes. If two super classes have Animal, Bird
{ Output:
same name for their members, then which member is inherited into the sub class is the main public void moves() D:\>javac InterfaceDemo2.java
confusion in multiple inheritance. This is the reason; Java does not support the concept of multiple { D:\>java InterfaceDemo2
System.out.println("animal move on land"); animal move on land
inheritance. This confusion is reduced by using multiple interfaces to achieve the concept of } birds fly in air
multiple inheritance.
JAVA Programming Dept of CSE, VVIT Page 55 JAVA Programming Dept of CSE, VVIT Page 56
UNIT II Inheritance UNIT II Inheritance
Hierarchical Inheritance: Only one base class but many derived classes. Multilevel Inheritance: In multilevel inheritance the class is derived from the derived class.
SUPERCLASS
Figure
A B C
EXTENDS
JAVA Programming Dept of CSE, VVIT Page 57 JAVA Programming Dept of CSE, VVIT Page 58
UNIT II Inheritance UNIT II Inheritance
Super Uses: Whenever a subclass needs to refer to its immediate super class, it can do so by 2. Accessing the member of a super class: The second form of super acts somewhat like this,
the use of the keyword super. except that it always refers to the superclass of the subclass in which it is used.
Super has the two general forms.
Syntax: super. member;
super (args-
super.member: To access a member of the super class that has been hidden by a member of a
Here, member can be either a method or an instance variable. This second form of super is most
subclass. Member may be variable or method.
applicable to situations in which member names of a subclass hide members by the same name in the
superclass. Consider this simple class hierarchy:
JAVA Programming Dept of CSE, VVIT Page 59 JAVA Programming Dept of CSE, VVIT Page 60
UNIT II Inheritance UNIT II Inheritance
e.g.: final abstract class A // invalid Importing Object class: java Library
Abstraction refers to the act of representing essential features without including the background lang package
details or explanations. Classes use the concept of abstraction and are defined as a list of attributes
Object class
and methods to operate on these attributes. They encapsulate all the essential features of the objects
that are to be created since the classes use the concept of data abstraction they are known as Abstract Object class is implicitly (automatically) imported into our source code, because it is in
Data Types. package. lang package is also implicitly imported into every java program.
Object class reference can store any reference of any object. This means that a reference variable of
type Object can refer to an object of any other class.
JAVA Programming Dept of CSE, VVIT Page 61 JAVA Programming Dept of CSE, VVIT Page 62
UNIT II Inheritance UNIT II Inheritance
final keyword: Final is a keyword in Java which generically means, cannot be changed once Final with classes: If we want the class not be sub-classed (or extended) by any other class, declare
created. Final behaves very differently for variables, methods and classes. it final. Classes declared final can not be extended. That is, any class can use the methods of a final
class by creating an object of the final class and call the methods with the object (final class object).
A final variable cannot be reassigned once initialized.
A final method cannot be overridden. Example program: {
A final class cannot be extended. import java.io.*; Demo1 d=new Demo1();
final class Demo1 d.display();
{ }
Classes are usually declared final for either performance or security reasons. public void display() }
{ Output:
Final with variables: Final variables work like constants of C- System.out.println("hi"); D:\>javac Demo3.java
} Demo3.java:9: cannot inherit from final
whole program. That is, f } Demo1
by all the program code. public class Demo3 extends Demo1 public class Demo3 extends Demo1
{ ^
public static void main(String args[]) 1 error
Example program: x=30;
import java.io.*; y=40;//error.
class FinalVar System.out.println("x is:"+x); Polymorphism:
{ System.out.println("y is:"+y); morphs same method has ability to take more than one form to perform
int x=10; }
final int y=20; } several tasks then it is called polymorphism. It is of two types:
System.out.println("x is:"+x); Output: [Error] Dynamic polymorphism(Runtime polymorphism)
System.out.println("y is:"+y); Cannot assign a value to final variable y
Static polymorphism(Compile time polymorphism)
Final with methods: Generally, a super class method can be overridden by the subclass if it wants a
Dynamic Polymorphism: The polymorphism exhibited at run time is called dynamic
different functionality or it can call the same method if it wants the same functionality. If the super
polymorphism. In this dynamic polymorphism a method call is linked with method body at the time
class desires that the subclass should not override its method, it declares the method as final. That is,
of execution by JVM. Java compiler does not know which method is called at the time of
methods declared final in the super class can not be overridden in the subclass (else it is compilation
compilation. This is also known as dynamic binding or run time polymorphism. Method
error). But, the subclass can access with its object as usual.
overloading and method overriding are examples of Dynamic Polymorphism in Java.
Example program: super.display();
import java.io.*; System.out.println("hello"); Method Overloading: Writing two or more methods with the same name with different
class A } parameters is called method over loading. In method overloading JVM understands which method
{ public static void main(String args[])
final void display() { is called depending upon the difference in the method parameters. The difference may be due to the
{ B b=new B(); following:
System.out.println("hi"); b.display();
} } Ø There is a difference in the no. of parameters.
} } void add (int a, int b) void add (int a, int b, int c)
class B extends A Output: [Error]
{ Display() in B cannot override display() in A; Ø There is a difference in the data types of parameters.
void display() //cannot override final method overridden method is final. void add (int a, float b) void add (double a, double b)
{
Ø There is a difference in the sequence of parameters.
void swap (int a, char b) void swap (char a, int b)
JAVA Programming Dept of CSE, VVIT Page 63 JAVA Programming Dept of CSE, VVIT Page 64
UNIT II Inheritance
Achieving method overloading & method overriding using instance methods is an example of
dynamic polymorphism.
Achieving method overloading & method overriding using static methods is an example of
Static Polymorphism.
JAVA Programming Dept of CSE, VVIT Page 66
JAVA Programming Dept of CSE, VVIT Page 65
UNIT II Inheritance UNIT II Inheritance
//Static Polymorphism When no access specifier is included, then default access results, and the interface is only
class Animal available to other members of the package in which it is declared. When it is declared as public,
{
static void move () the interface can be used by any other code. In this case, the interface must be the only public
{ interface.
System.out.println ("Animals can move");
} Note: that the methods are declared have no bodies. They end with a semicolon after the
} parameter list. They are, essentially, abstract methods; there can be no default implementation
class Dog extends Animal
{ of any method specified within an interface. Each class that includes an interface must
static void move () implement all of the methods.
{
System.out.println ("Dogs can walk and run"); Variables can be declared inside of interface declarations. They are implicitly final and static,
} meaning they cannot be changed by the implementing class. They must also be initialized. All
}
public class StaticPoly methods and variables are implicitly public.
{
public static void main(String args[])
Example:
{
Animal.move (); public interface animal
Dog.move (); {
} void display();
} }
Output:
D:\>javac StaticPoly.java
D:\>java StaticPoly Implementing Interfaces:
Animals can move Once an interface has been defined, one or more classes can implement that interface.
Dogs can walk and run
To implement an interface, include the implements clause in a class definition, and then
Interfaces: An interface is defined much like as an abstract class (it contains only method create the methods defined by the interface.
JAVA Programming Dept of CSE, VVIT Page 67 JAVA Programming Dept of CSE, VVIT Page 68
UNIT II Inheritance UNIT II Inheritance
JAVA Programming Dept of CSE, VVIT Page 69 JAVA Programming Dept of CSE, VVIT Page 70
UNIT II Packages and Interfaces UNIT II Packages and Interfaces
An interface is used to allow unrelated objects to interact with one another, by implementing an
Interfaces vs. Abstract Classes: Abstract class and interface both are used to achieve
agreed upon system of behavior. When a class implements an interface, the class agrees to
abstraction where we can declare the abstract methods. Abstract class and interface both can't be
implement all of the methods defined in the interface. Interfaces are useful since they capture
instantiated.
similarity between unrelated objects without forcing a class relationship. Furthermore,
But there are many differences between abstract class and interface that are given below.
interfaces may consist of abstract methods. One class uses an interface by using
Abstract class Interface
the "implements" keyword.
Abstract class can have abstract and non-abstract Interface can have only abstract methods.
methods.
Classes in Java have its particular fields and methods. Each object is an instance of a class, and
Abstract class doesn't support multiple Interface supports multiple inheritance.
follows the class prototype that defines the variables and methods common to all objects of a inheritance.
certain kind. Each instance of a class must be instantiated, after it is declared, unlike in C++. Abstract class can have final, non-final, static Interface has only static and final variables.
and non-static variables.
This is usually done with the keyword "new". Classes may have inheritance from other classes, Abstract class can have static methods, main Interface can't have static methods, main method
as they do in C++, meaning they inherit all the properties of the parent class. This is usually method and constructor. or constructor.
Abstract class can provide the implementation of Interface can't provide the implementation of
done with the keyword "extends". interface. abstract class.
The abstract keyword is used to declare abstract The interface keyword is used to declare
class. interface.
Property Class Interface Example: Example:
public abstract class Shape{ public interface Drawable{
Instantiation Can Be Instantiated Can not be instantiated public abstract void draw(); void draw();
} }
Inheritance A Class can inherit only one An Interface cannot inherit any Package: Packages are containers for classes that are used to keep the class name space
Class and can implement many classes while it can extend many compartmentalized. Packages are stored in a hierarchical manner and are explicitly imported
interfaces interfaces into new class definitions. Packages are of two types Built-in packages and User-defined
packages.
Variables All the variables are instance by All the variables are static final by
Built-in packages are already available in java language which contains classes, interfaces and
default unless otherwise default, and a value needs to be
specified assigned at the time of definition methods for the programmer to perform any task. Ex: java.lang, java.util etc.
User-defined packages can be created by the users of java which can be imported to other
Methods All the methods should be All the methods are abstract by classes and used exactly in the same way as the Built-in packages.
having a definition unless default and they will not have a Creating a Package: To create a package is quite easy: simply include a package
decorated with an abstract definition.
command as the first statement in a Java source file. Any classes declared within that file will
keyword
belong to the specified package.
The package statement defines a name space in which classes are stored.
If you omit the package statement, the class names are put into the default package, which
has no name.
D:\Sub>javac d . Addition.java package. This command generates a class file and stores in pack package.
The preceding command means create a package (-d) in the current directory (.) and store D:\Sub>java pack.Subtraction
Addition.class file there in the package. The package name is specified in the program as pack. The preceding command is used for executing the Subtraction class file which is in pack
So the Java compiler creates a directory in D:\Sub with the name as pack and stores package.
Addition.class there. Observe it by going to pack sub directory which is created in D:\Sub. So, Difference= 100.00
our package with Addition class is ready.
**Second, you can specify a directory path or paths by setting the CLASSPATH Example:
environmental variable. import pack.*;
class Use
**Third, you can use the -classpath option with java and javac to specify the path to your {
classes. public static void main(String args[])
{
Example: package MyPack; Addition obj=new Addition obj(10,23.0);
In order for a program to find MyPack, one of three things must be true. Either the program can Subtraction s=new Subtraction(213,200.0)
obj.sum();
be executed from a directory immediately above MyPack, or the CLASSPATH must be set to }
include the path to MyPack, or the -classpath option must specify the path to MyPack when }
C:\>javac Use.java
the program is run via java. C:\>java Use
When the second two options are used, the class path must not include MyPack, itself.It Sum= 33.0
Difference= 13.00
must simply specify the path to MyPack.
The four access specifiers, private, public, protected and default, provide a variety of Save as SamePackage.java in package p1: Main method class for package p1: save in
ways to produce the many levels of access required by these categories. package p1; current directory
public class SamePackage import p1.*;
{ public class Demo
Private Default Protected Public public SamePackage() {
Same class Yes Yes Yes Yes { public static void main(String args[])
Protection p = new Protection(); {
Same package subclass No Yes Yes Yes
System.out.println("same package Protection ob1 = new Protection();
constructor"); Derived ob2 = new Derived();
Same package non-subclass No Yes Yes Yes
System.out.println("n = " + p.n); SamePackage ob3 = new SamePackage();
System.out.println("n_pro = " + p.n_pro); }
Different package subclass No No Yes Yes
System.out.println("n_pub = " + p.n_pub); }
Different package non- No No No Yes
}}
subclass
n_pub = 4
Example: }
derived constructor
Save as Protection.java in package p1: }
Output: n=1
package p1; Save as Derived.java in package p1:
D:\>javac p1/Protection.java n_pro = 3
public class Protection package p1;
D:\>javac p1/Derived.java n_pub = 4
{ public class Derived extends Protection
D:\>javac p1/SamePackage.java base constructor
int n = 1; {
D:\>javac Demo.java n=1
private int n_pri = 2; public Derived()
D:\>java Demo n_pri = 2
protected int n_pro = 3; {
base constructor n_pro = 3
public int n_pub = 4; System.out.println("derived constructor");
n=1 n_pub = 4
public Protection() System.out.println("n = " + n);
n_pri = 2 same package constructor
{ System.out.println("n_pro = " + n_pro);
n_pro = 3 n=1
System.out.println("base constructor"); System.out.println("n_pub = " + n_pub);
n_pub = 4 n_pro = 3
System.out.println("n = " + n); }
base constructor n_pub = 4
System.out.println("n_pri = " + n_pri); }
n=1
System.out.println("n_pro = " + n_pro);
n_pri = 2
System.out.println("n_pub = " + n_pub);
n_pro = 3
OOP Through JAVA Page 79 OOP Through JAVA VVIT, CSE Dept. Page 80
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
Exception Handling Exception handling means to handle the exceptions by the programmer to recover the computer from
malfunction due to exceptions.
Errors in a Java Program: There are two types of errors, compile time errors and run time errors.
Compile time errors: These are syntactical errors found in the code, due to which a program fails to In Java, exception handling is managed via five keywords: try, catch, throw, throws, and finally.
compile. For example, forgetting a semicolon at the end of a Java statement, or writing a statement
try: The try block is said to monitor the statements enclosed within it and defines the scope of any
without proper syntax will result in compile-time error. Detecting and correcting compile-time
exception associated with it. It detects the exceptions.
errors is easy as the Java compiler displays the list of errors with the line numbers along with their
catch: The catch clause contains a series of legal Java statements. These statements are executed if
description. The programmer can go to the statements, check them word by word and line by line to
and when the exception handler is invoked. It holds an exception. Catch is known as exception
understand where he has committed the errors.
handler which is a piece of code used to deal with the exceptions, either to fix the error or abort
Run time errors: The run time errors are the errors that occur at the run-time of the program and
execution in a sophisticated way.
cause the abnormal termination of the program. The run time errors are called exceptions. There are
throw: To manually throw an exception ,use the keyword throw.
the three types of runtime errors.
throws: Any exception that is thrown out of a method must be specified as such by a throws clause.
Input errors: Input errors occur if the user provides unexpected inputs to the program. For
finally: Any code that absolutely must be executed after a try block completes is put in a finally
example, if the program wants an integer and the user provides it the string value. These errors can
block. After the exception handler has run, the runtime system passes control to the finally block.
be prevented from occurring by prompting the user to enter the correct type of values.
System errors: System errors or hardware errors occur rarely. These errors occur due to unreliable Syntax:
try
{
Logical errors: logical errors occur if the program is logically incorrect. These errors either // block of code to monitor for errors
}
generate incorrect results or terminate program abnormally. For example, a program for adding catch (ExceptionType1 id1 )
{
two numbers requires an addition operator (+), if the program supplies subtraction operator (-) // exception handler for ExceptionType1
}
then this generates the incorrect results. To debug these errors the program must be scanned to catch ( ExceptionType2 id2 )
{
check the logical statements. // exception handler for ExceptionType2
} .
.
Introduction to Exception Handling: Java applications are used in embedded system software, .
which runs inside specialized devices like hand held computers, cellular phones, and etc. in those kinds finally
{
software errors be handled strongly. Java offers a solution // statements to execute every time after try block executes
}
to these problems with exception handling. Here, ExceptionType is the type of exception that has occurred.
Concepts of Exception Handling: An Exception is an abnormal condition that arises during the Exception Hierarchy: All exception types are subclasses of the built-in class Throwable, where
execution of a program that causes to deviate from the normal flow of execution path. When an Throwable is subclass for . Thus, Throwable is at the top of the exception class hierarchy.
exception occurs, it makes the further execution of the program impossible. Thus, an exception can be Immediately below Throwable, there are two subclasses that partition exceptions into two distinct
defined as an event that may cause abnormal termination of the program during its execution. branches.
OOP Through JAVA VVIT, CSE Dept. Page 81 OOP Through JAVA VVIT, CSE Dept. Page 82
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
to indicate errors having to do with the run-time environment, itself. Stack overflow is an example of
such an error.
Checked Exceptions: Checked exceptions are the exceptions thrown by a method, if it encounters a
situation which is not handled by it.
RuntimeException
by compiler to determine whether it throws checked exceptions or not.
Programmer should compulsorily handle the checked exceptions in code, otherwise code will not be
compiled i.e. the code which may cause checked exception must be specified in try-catch block or
throws clause containing the list of checked exception is provided to the method declaration.
One branch is headed by Exception. This class is used for exceptional conditions that user programs "Checked" means they will be checked at compile time itself.
should catch. This is also the class that you will subclass to create your own user defined exception
The example of Checked Exceptions is IOException which should be handled in code compulsorily or
types. There is an important subclass of Exception, called RuntimeException. Exceptions of this type are
else code will throw a Compilation Error.
automatically defined for the programs that you write and include things such as division by zero and
invalid array indexing.
The other branch is topped by Error, which defines exceptions that are not expected to be caught under
normal circumstances by your program. Exceptions of type Error are used by the Java run-time system
OOP Through JAVA VVIT, CSE Dept. Page 83 OOP Through JAVA VVIT, CSE Dept. Page 84
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
Example:
Unchecked Exceptions: Exceptions which are checked at run time. A java method does not require
declaring that it will throw any of the run-time exception. Unchecked exceptions are RuntimeException
and any of its subclasses and Class Error and its subclasses also are unchecked. Unchecked runtime
exceptions represent conditions that reflect errors in program's logic and cannot be reasonably recovered
from at run time. With an unchecked exception, compiler doesn't force programmers either to catch the
exception or declare it in a throws clause.
Example: System.out.println("okay");
public class REDemo }
{ } Benefits of Exception Handling:
static public void main(String args[]) Output:
{ D:\Seshu\Except>javac CEDemo.java
First, it allows you to fix the error.
int d[]={1,2}; D:\Seshu\Except>java REDemo
d[3]=99; Exception in thread "main" Second, it prevents the program from automatically terminating.
int a=5,b=0,c; java.lang.ArrayIndexOutOfBoundsException: 3
Third, it adopts the robustness to program.
c=a/b; at REDemo.main(CEDemo.java:6)
System.out.println("c is:"+c);
Exception handling provides the following advantages over ''traditional'' error management techniques:
Separating Error Handling Code from ``regular'' one: provides a way to separate the details of
what to do when something out-of-the-ordinary happens from the normal logical flow of the
program code;
Propagating Errors up the Call Stack: lets the corrective action to be taken at a higher level. This
allows the corrective action to be taken in the method that calling that one where an error occurs;
Grouping Error Types and Error Differentiation: Allows to create similar hierarchical structure
for exception handling so groups them in logical way.
OOP Through JAVA VVIT, CSE Dept. Page 85 OOP Through JAVA VVIT, CSE Dept. Page 86
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
exception has been thrown, it must be caught by an exception handler and dealt with immediately. In at Exc1.subroutine(Exc1.java:6)
this example, no exception handlers are specified, so the exception is caught by the default handler at Exc1.main(Exc1.java:10)
provided by the Java run-time system. Any exception that is not caught by your program will ultimately
As you can see, the bottom of the stack is main subroutine( ), which caused
be processed by the default handler. The default handler displays a string describing the exception,
the exception at line 4. The call stack is quite useful for debugging, because it pinpoints the precise
prints a stack trace from the point at which the exception occurred, and terminates the program.
sequence of steps that led to the error.
OOP Through JAVA VVIT, CSE Dept. Page 87 OOP Through JAVA VVIT, CSE Dept. Page 88
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
catch: A catch clause is a group of java statements, enclosed in braces { } which are used to handle a Division by zero.
specific exception that has been thrown. Catch clauses should be placed after the try block i.e. catch After catch statement.
A catch clause is specified by the keyword catch followed by a single argument within parenthesis (). program control transfers out of the try block into the catch block.
The argument type in a catch clause is form the Throwable class or one of its subclasses.
Displaying a Description of an Exception: Throwable overrides the toString ( ) method (defined by
Once the catch statement has executed, program control continues with the next line in the program Object). So that it returns a string containing a description of the exception. We can display this
following the entire try/catch mechanism. description in a println ( ) statement by simply passing the exception as an argument. For example, the
A try and its catch statement form a unit. The scope of the catch clause is restricted to those catch block in the preceding program can be rewritten like this:
statements specified by the immediately preceding try statement. A catch statement cannot catch an catch (ArithmeticException e)
{
exception thrown by another try statement (except in the case of nested try statements) System.out.println("Exception: " + e);
The statements that are protected by try must be surrounded by curly braces. (That is, they must be a = 0; // set a to zero and continue
}
within a block.) We cannot use try on a single statement.
When this version is substituted in the program, and the program is run, each divide-by-zero error
The goal of most well-constructed catch clauses should be to resolve the exceptional condition and
displays the following message:
then continue on as if the error had never happened.
Exception: java.lang.ArithmeticException: / by zero
To illustrate how easily this can be done, the following program includes a try block and a catch clause
that processes the ArithmeticException generated by the division-by-zero error: Multiple catch Statements:
class Exc2
In some cases, more than one exception could be raised by a single piece of code. To handle this type of
{
public static void main(String args[]) situation, we can specify two or more catch clauses, each catching a different type of exception. When
{
an exception is thrown, each catch statement is inspected in order, and the first one whose type matches
int d, a;
try that of the exception is executed. After one catch statement executes, the others are bypassed, and
{ // monitor a block of code.
execution continues after the try/catch block. The following example traps two different exception types:
d = 0;
a = 42 / d;
System.out.println("This will not be printed."); Example:
} class MultiCatch
catch (ArithmeticException e) {
{ // catch divide-by-zero error public static void main(String args[])
System.out.println("Division by zero."); {
} try
System.out.println("After catch statement."); {
} int a = args.length;
} System.out.println("a = " + a);
int b = 42 / a;
This program generates the following output:
OOP Through JAVA VVIT, CSE Dept. Page 89 OOP Through JAVA VVIT, CSE Dept. Page 90
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
OOP Through JAVA VVIT, CSE Dept. Page 91 OOP Through JAVA VVIT, CSE Dept. Page 92
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
then a divide-by-zero exception then appropriate action will take place. Only the expressions thrown by the java run-time system are
will be generated by the following code. */ being caught, but throw keyword allows a program to throw an exception explicitly.
if(a==1) a = a/(a-a); // division by zero
/* If two command-line args are used, then generate an out-of-bounds exception. */
if(a==2) Syntax: throw ThrowableInstance;
{
int c[] = { 1 }; Here, ThrowableInstance must be an object of type Throwable or a subclass of Throwable. Primitive
c[42] = 99; // generate an out-of-bounds exception
} types, such as int or char, as well as non-Throwable classes, such as String and Object, cannot be used as
} exceptions.
catch(ArrayIndexOutOfBoundsException e)
{
System.out.println("Array index out-of-bounds: " + e); There are two ways you can obtain a Throwable object:
}
}
using a parameter in a catch clause:: catch(NullPointerException e) { throw e; }
catch(ArithmeticException e)
{ Creating one with the new operator:: throw new ArithmeticException ();
System.out.println("Divide by 0: " + e);
}
} The flow of execution stops immediately after the throw statement; any subsequent statements are not
} executed.
As you can see, this program nests one try block within another. The program works as follows.
The nearest enclosing try block is inspected to see if it has a catch statement that matches the type of
C:\>java NestTry exception. If it does find a match, control is transferred to that statement. If not, then the next enclosing
Divide by 0: java.lang.ArithmeticException: / by zero
C:\>java NestTry One try statement is inspected, and so on. If no matching catch is found, then the default exception handler
a=1 halts the program and prints the stack trace.
Divide by 0: java.lang.ArithmeticException: / by zero
C:\>java NestTry One Two
a=2 Example:
Array index out-of-bounds: class ThrowDemo
java.lang.ArrayIndexOutOfBoundsException:42 {
static void demoproc()
{
When we execute the program with no command-line arguments, a divide-by-zero exception is try
generated by the outer try block. Execution of the program with one command-line argument generates a {
throw new NullPointerException("demo");
divide-by-zero exception from within the nested try block. Since the inner block does not catch this }
exception, it is passed on to the outer try block, where it is handled. If we execute the program with two catch(NullPointerException e)
{
command-line arguments, an array boundary exception is generated from within the inner try block. System.out.println("Caught inside demoproc.");
throw e; // rethrow the exception
throw: }
}
arrival of error and when an error occurs it throws the error and it is caught by the catch statement and public static void main(String args[])
{
OOP Through JAVA VVIT, CSE Dept. Page 93 OOP Through JAVA VVIT, CSE Dept. Page 94
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
try Syntax:
{ returntype method-name(parameter-list) throws exception-list
demoproc(); {
} // body of method
catch(NullPointerException e) }
{
System.out.println("Recaught: " + e); Here, exception-list is a comma-separated list of the exceptions that a method can throw. Following is an
}
} example of an incorrect program that tries to throw an exception that it does not catch. Because the
} program does not specify a throws clause to declare this fact, the program will not compile.
Here, new is used to construct an instance of NullPointerExcepti - in run-time To make this example compile, you need to make two changes.
exceptions have at least two constructors: one with no parameter and one that takes a string parameter.
First, you need to declare that throwOne( ) throws IllegalAccessException.
When the second form is used, the argument specifies a string that describes the exception. This string is
displayed when the object is used as an argument to print( ) or println( ). It can also be obtained by a call Second, main( ) must define a try/catch statement that catches this exception.
OOP Through JAVA VVIT, CSE Dept. Page 95 OOP Through JAVA VVIT, CSE Dept. Page 96
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
} Here is an example program that shows three methods that exit in various ways, none without
catch (IllegalAccessException e) executing their finally clauses:
{
System.out.println("Caught " + e);
} // Demonstrate finally. try
} class FinallyDemo {
} { System.out.println("inside procC");
// Through an exception out of the method. }
static void procA() finally
Here is the output generated by running this example program: {
{
inside throwOne System.out.println("procC's finally");
try
caught java.lang.IllegalAccessException: demo }
{
System.out.println("inside procA"); }
What is the difference between throws and throw? throw new RuntimeException("demo"); public static void main(String args[])
} {
throws clause is used when the programmer does not want to handle the exception and throw it out of a finally try
method. throw clause is used when the programmer wants to throw an exception explicitly and wants to { {
System.out.println("procA's finally"); procA();
handle it using catch block. Hence, throws and throw are contradictory. } }
} catch(Exception e)
finally: // Return from within a try block. {
static void procB()
{ }
Whenever an exception occurs, the exception affects the flow of execution of the program. Sometimes try }
some blocks may be bypassed by exception handling. For example, if a method opens a file upon entry { procB();
System.out.println("inside procB"); procC();
and closes it upon exit, then you will not want the code that closes the file to be bypassed by the return; }
exception-handling mechanism. The finally keyword is designed to address this contingency. } }
finally
{ Output:
finally creates a block of code that will be executed after a try/catch block has completed and before System.out.println("procB's finally"); inside procA
the code following the try/catch block. }
} Exception caught
The finally block will execute whether or not an exception is thrown. If an exception is thrown, the inside procB
finally block will execute even if no catch statement matches the exception.
// Execute a try block normally. inside procC
Any time a method is about to return to the caller from inside a try/catch block, via an uncaught static void procC()
exception or an explicit return statement, the finally clause is also executed just before the method {
In this example, procA( ) prematurely breaks out of the try by throwing an exception.
returns.
This can be useful for closing file handles and freeing up any other resources that might have been
statement.
allocated at the beginning of a method with the intent of disposing of them before returning.
The finally clause is executed before procB( ) returns. In procC( ), the try statementexecutes
The finally clause is optional. However, each try statement requires at least one catch or a finally
normally, without error. However, the finally block is still executed.
clause.
OOP Through JAVA VVIT, CSE Dept. Page 97 OOP Through JAVA VVIT, CSE Dept. Page 98
UNIT II Exception Handling and Multi-Threading UNIT II Exception Handling and Multi-Threading
NOTE: If a finally block is associated with a try, the finally block will be executed upon conclusion of
the try.
Creating own Exception Sub Classes: Although Jav -in exceptions handle most common
errors, we will probably want to create our own exception types to handle situations specific to our
applications. This is quite easy to do: just define a subclass of Exception (which is, of course, a subclass
of it is their existence in the
type system that allows us to use them as exceptions.
The Exception class does not define any methods of its own. It does, of course, inherit those methods
provided by Throwable. Thus, all exceptions, including those that you create, have the methods defined
by Throwable available to them. They are shown in Table.
We may also wish to override one or more of these methods (shown in table) in exception classes that
you create.
Exception defines 2 constructors.
Exception( )
Exception(String msg)
The first form creates an exception that has no description. The second form lets us specify a description
The following example declares a new subclass of Exception and then uses that subclass to signal an
of the exception. Although specifying a description when an exception is created is often useful, error condition in a method. It overrides the toString( ) method, allowing a carefully tailored description
of the exception to be displayed.
Throwable (and inherited by Exception) first displays the name of the exception followed by a colon,
which is then followed by your description. By overriding toString( ), we can prevent the exception // This program creates a custom exception type. {
class MyException extends Exception static void compute(int a) throws MyException
name and colon from being displayed. This makes for a cleaner output, which is desirable in some cases. {
{
private int detail; System.out.println("Called compute(" + a +
MyException(int a) ")");
{ if(a > 10)
detail = a; throw new MyException(a);
} System.out.println("Normal exit");
public String toString() }
{ public static void main(String args[])
return "MyException[" + detail + "]"; {
} try
} {
class ExceptionDemo compute(1);
OOP Through JAVA VVIT, CSE Dept. Page 99 OOP Through JAVA VVIT, CSE Dept. Page 100
UNIT II Exception Handling and Multi-Threading
compute(20); }
}
catch (MyException e) Here is the result:
{ Called compute(1)
System.out.println("Caught " + e); Normal exit
} Called compute(20)
} Caught MyException[20]
This example defines a subclass of Exception called MyException. This subclass is quite simple: it has
only a constructor plus an overloaded toString( ) method that displays the value of the exception. The
ExceptionDemo class defines a method named compute( ) that throws a MyException object. The
an exception handler for MyException, then calls compute( ) with a legal value (less than 10) and an
illegal one to show both paths through the code.