KEMBAR78
Unit 2 Java | PDF | Inheritance (Object Oriented Programming) | Method (Computer Programming)
0% found this document useful (0 votes)
50 views56 pages

Unit 2 Java

The document discusses the concept of inheritance in Java, highlighting its importance in Object Oriented Programming (OOP) and defining key terms such as superclass and subclass. It explains different types of inheritance, including single, hierarchical, and multilevel inheritance, along with examples and code snippets. Additionally, it covers the use of the 'super' keyword, method overriding, and dynamic method dispatch, illustrating how these concepts facilitate code reusability and polymorphism.

Uploaded by

andemhindu
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)
50 views56 pages

Unit 2 Java

The document discusses the concept of inheritance in Java, highlighting its importance in Object Oriented Programming (OOP) and defining key terms such as superclass and subclass. It explains different types of inheritance, including single, hierarchical, and multilevel inheritance, along with examples and code snippets. Additionally, it covers the use of the 'super' keyword, method overriding, and dynamic method dispatch, illustrating how these concepts facilitate code reusability and polymorphism.

Uploaded by

andemhindu
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/ 56

TOPIC 1

Inheritance is an important pillar of OOP(Object Oriented Programming). It is the process in java by which one class is
allow to inherit the features(fields and methods) of another class.
Important terminology:
 Super Class: The class whose features are inherited is known as super class(or a base class or a parent class).
 Sub Class: The class that inherits the other class is known as sub class(or a derived class, extended class, or child
class). The subclass can add its own fields and methods in addition to the superclass fields and methods.
 Reusability: Inheritance supports the concept of “reusability”, i.e. when we want to create a new class and there is
already a class that includes some of the code that we want, we can derive our new class from the existing class.
By doing this, we are reusing the fields and methods of the existing class.

Example Inheritance is used to achieve IS-A


relationship .
Simple
Inheritance

-
Example
PARENT

Example

CHILD
Example
The keyword used for inheritance is extends.
Syntax:
class Sub-classname extends Super-classname
{
Declaration of variables;
Declaration of methods;
}
Example:
class SimpleInheritance {
class Circle
public static void main(String args[])
{ Circle() { }
{ double vol;
private int radius;
Cone cn=new Cone();
void setRadius(int radius){
this.radius= radius;
cn. setRadius(5);
}
cn.setHeight(10);
int getRadius(){
vol=cn.volume();
return radius;
System.out.println(vol);
}
}
double computeArea(){
}
return (3.141*radius*radius);
As you can see sub class Cone can access methods of Circle but not data
}
member, because radius of super class is declared as private. sub class
double comutePerimeter(){
can’t inherit the private properties of super class.
return 2*3.141*radius;
}
}
class Cone extends Circle{
int height;
Cone() { }
void setHeight(int height){
this.height= height;
}
int getHeight(){
return height;
}
double volume(){
double v=(computeArea() *height )/3;
return v;
}
}
What You Can Do in a Subclass
A subclass inherits all of the public,defult and protected members of its parent. The inherited fields can be used directly
just like any other fields.
 You can declare new fields in the subclass that are not in the superclass.
 The inherited methods can be used directly as they are.
 You can write a new instance method in the subclass that has the same signature as the one in the superclass,
thus overriding it.
 You can declare new methods in the subclass that are not in the superclass.
 You can write a subclass constructor that invokes the constructor of the superclass, either implicitly or by using the
keyword super.
Private Members in a Superclass
A subclass does not inherit the private members of its parent class. However, if the superclass has public or protected
methods for accessing its private fields, these can also be used by the subclass.
TOPIC 2
Types of Inheritance in Java
Single Inheritance : In single inheritance, subclasses inherit the features of one superclass. In image below, the
class A serves as a super class for the sub class B
Example for Single Level Inheritance
class SimpleInheritance {
class Circle
public static void main(String args[])
{ Circle() { }
{ double vol;
private int radius;
Cone cn=new Cone();
void setRadius(int radius){
this.radius= radius;
cn. setRadius(5);
}
cn.setHeight(10);
int getRadius(){
vol=cn.volume();
return radius;
System.out.println(vol);
}
}
double computeArea(){
}
return (3.141*radius*radius);
As you can see sub class Cone can access methods of Circle but not data
}
member, because radius of super class is declared as private. sub class
double comutePerimeter(){
can’t inherit the private properties of super class.
return 2*3.141*radius;
}
}
class Cone extends Circle{
int height;
Cone() { }
void setHeight(int height){
this.height= height;
}
int getHeight(){
return height;
}
double volume(){
double v=(computeArea() *height )/3;
return v;
}
}
2.Hierarchical Inheritance : In Hierarchical Inheritance, one class serves as a superclass (base class) for
more than one sub class.
Example for hierarchical inheritance and the concerned code
Person
Example
Name
setName()
getName()

Student Teacher
Studno Empid
Basicpay
setStudno()
getStudno() setEmpid()
setBasicPay()
getEmpid()
getBasicPay()
code
import java.io.*; void displayStudentData(){
class Person { displayPersonData();
•-
private String name; System.out.println("Student no"+studno);
Person() { } System.out.println(“Name"+ getName());
Person(String name) {
this.name=name; }}// student close
} class Teacher extends Person{
void setName(String N){ int Empid;
name=N; double BasicPay
}
String getName(){ Teacher(){}
return name; Teacher(String name, int Empid,double bp){
} super(name);
void displayPersonData(){ this.Empid=Empid;
System.out.println("First Name"+name);
}}//PERSON CLASS CLASE this.BasicPay= bp;
class Student extends Person{ }
int studno; void setEmpid( int eid){
Student() { } Empid=eid;
Student(String name, int studno) {
super(name); }
this.studno=studno; void setBasicPay(double slry){
} this.BasicPay=slry;
void setStudno(int sno){ }
studno=sno; int getEmpid(){
}
int getStudno(){ return Empid;
return studno; }
} double getBasicPay(){
return BasicPay;
}
void displayTeacherData()
{
System.out.println("Employee id"+Empid);
System.out.println(“Name “+getName());
System.out.println("Salary"+BasicPay);
} Write some theory about this
}// Teacher close

public class HierarchiMain{


public static void main(String[] args){
Student S=new Student();
Teacher T=new Teacher(“SARADA”, 110,
20000);

S.setStudno(101);
S.setName(“RAVI”);
S.displayStudentData();
T.displayTeacherData();
}
}
2 Level Multilevel Inheritance

CLASS A

Multilevel Inheritance : In Multilevel Inheritance, a derived


class will be inheriting a super class and as well as the CLASS B
derived class also act as the base class to other class. In
the given image, the class A serves as a super class for
the derived class B, which in turn serves as a super class
for the derived class C.

CLASS C
Person
Exampl Name
e setName()
getName()

Student

Studno
setStudno()
getStudno()
displayStudentdata()

Test
Sub1
Sub2
Tmarks
setSub1()
setSub2()
getSub1()
Getsub2()
computeTotal()
displayTotal()
code
import java.io.*;
void displayStudentData(){
class Person {
displayPersonData();
private String name; System.out.println("Student no"+studno);
Person() { } System.out.println(“Name"+ getName());
Person(String name) { }}// student close
this.name=name;
} class Test extends Student
void setName(String N){ {double Sub1, Sub2;
name=N; double Tmarks;
} Test(){}
String getName(){ }
return name; void displayTotal(){
} System.out.println("TOTAL MARKS "+Tmarks);
void displayPersonData(){ }
System.out.println(“Name "+Name); void computeTmarks(){
}}//PERSON CLASS CLASE Tmarks= Sub1+Sub2;
class Student extends Person{
int studno; }}// Test close
WRITE SOMETHING
Student() { } public class MultiLevelMain ABOUT THIS
Student(String name, int studno) {
{
super(name); public static void main(String[] args)
this.studno=studno; {
} Test T=new Test();
void setStudno(int sno){ T.readData();
studno=sno; T.computeTmarks();
} T.displayTotal();
int getStudno(){ }
return studno; }
} /*Incomplete code…Fill it*/
Important facts about inheritance in Java
 Default superclass: Except Object class, which has no superclass, every class has one and only one direct
superclass (single inheritance). In the absence of any other explicit superclass, every class is implicitly a subclass
of Object class.
 Superclass can only be one: A superclass can have any number of subclasses. But a subclass can have
only one superclass. This is because Java does not support multiple inheritance with classes. Although with
interfaces, multiple inheritance is supported by java.
 Inheriting Constructors: A subclass inherits all the members (fields, methods, and nested classes) from its
superclass. Constructors are not members, so they are not inherited by subclasses, but the constructor of the
superclass can be invoked from the subclass.
 Private member inheritance: A subclass does not inherit the private members of its parent class. However, if the
superclass has public or protected methods(like getters and setters) for accessing its private fields, these can
also be used by the subclass.
Topic 3:
Super Keyword in Java
The super keyword in java is a reference variable that is used to refer parent class objects. The keyword “super”
came into the picture with the concept of Inheritance. It is majorly used in the following contexts:
Use of super with variables: This scenario occurs when a derived class and base class has same data members. In
that case there is a possibility of ambiguity . We can understand it more clearly using this code snippet:

In this example, both base class and subclass have a


member maxSpeed. We could access maxSpeed of base
class in sublcass using super keyword.
2. Use of super with methods: This is used when we want to call parent class method. So whenever a parent and child class have same named methods
then to resolve ambiguity we use super keyword. This code snippet helps to understand the said usage of super keyword.
//Base class Person
class Person{
void message() {
System.out.println("This is person class");
}
}
/* Subclass Student */
class Student extends Person{
void message(){
System.out.println("This is student class");
}
void display(){
message();
super.message();
}
}
/* Driver program to test */
class Test{
public static void main(String args[]){
Student s = new Student();
// calling display() of Student
s.display();
}
}
In the above example, we have seen that if we only call method message() then, the current class message() is invoked but with the use of super
keyword, message() of superclass could also be invoked.
3. Use of super with constructors: super keyword can also be used to access the parent class constructor. One more
important thing is that, ‘super’ can call both parametric as well as non parametric constructors depending upon the
situation. Following is the code snippet to explain the above concept:
The following figure shows the order of constructor invocation and order of execution. Invocation takes place from
bottom class to top class and execution takes place from top to bottom.
Example
/* superclass Person */
class Person{ Example to demonstrate invocation super
private String Name;
Person() { }
class parameterized constructor from sub
Person(String N) class
/* Driver program to test*/
{ Name=N; }
void setName(String N){ class Test{
Name=N;
} public static void main(String[] args){
String getName(){ Student s = new Student(7,”Akhil”);
return Name; s.display();
}}
}
/* subclass Student extending the Person class */
class Student extends Person{
int studno;
Student() { }
Other Important points:
Student(int studno, String N) { 1.**Call to super() must be the first statement in Derived(Student) Class
super(N); constructor.
this.studno=studno;
} 2.If a constructor does not explicitly invoke a superclass constructor, the Java
void setStudno(int no){ compiler automatically inserts a call to the no-argument constructor of the
studno=no; superclass. If the superclass does not have a no-argument constructor, you
}
int getStudno(){ will get a compile-time error
return studno;
}
void display(){
System.out.println( ”Student number is “+studno);
System.out.println( ”Student Name is “+getName());
}}
Topic 4:
Method Overriding:
1.In a class hierarchy, when a method in a subclass has the same name and type signature as a method in its superclass, then
the method in the subclass is said to override the method in the superclass.
2.When an overridden method is called from within a subclass, it will always refer to the version of that method defined by the
subclass.
3.The version of the method defined by the superclass will be hidden.
Consider the following Example:
class Animal{
void walk(){
In this example eat() of Dog subclass
}
System.out.println(“I am walking”);
overridden the eat() method of animal
void eat(){

}
System.out.println(“I am eating”); super class.So ,d.eat() method invokes
class Dog extends Animal{
void bark(){ subclass eat() method.
System.out.println(“I am barking”);
}
void eat(){
System.out.println(“I am eating non-veg”);
}
}
class MOTest{
public static void main (String[] args){
Dog d=new Dog();
d.eat();
}
}
Method Overriding Example 2:
When show( ) is invoked on an object of type B, the version of show( ) defined within B
is used. That is, the version of show( ) inside B overrides the version declared in A.
Example
Class B extends A{
double k;
B() { }
class A B(int i, int j,int k){
{ double i,j; super(i,j);
A() { } this.k=k;
A(int i,int j){ }
void show()// this method overrides{
this.i=i;
System.out.println(“i=“+i+”j=“+j);
this.j=j; System.out.println(“k=“+k);
} }
void show(){ Public class Mainclass{
System.out.println(“i=“+i+”j=“+j); public static void main(String[] args){
} B obj= new B(1,2,3);
} obj.show();
}
}
TOPIC 5
Dynamic Method Dispatch
Dynamic method dispatch is the mechanism by which a call to an overridden method is resolved at run time, rather
than compile time. Dynamic method dispatch is important because this is how Java implements run-time
polymorphism.

Method overriding forms the basis for one of Java’s most powerful concepts: dynamic method dispatch.

In inheritance a superclass reference variable can refer to a subclass object. Java uses this fact to resolve calls to
overridden methods at run time. When an overridden method is called through a superclass reference, Java
determines which version of that method to execute based upon the type of the object being referred to at the time
the call occurs. Thus, this determination is made at run time. When different types of objects are referred to,
different versions of an overridden method will be called.
An example that illustrates dynamic method dispatch:
Dynamic Method Dispatch Example:
This program creates one superclass called A and sub class B .
Subclasses B override show( ) declared in A. Inside the main( ) method, a reference of type A, called obj , is
declared. The program then in turn assigns a reference to each type of object to obj and uses that reference to
invoke show( ). As the output shows, the version of show( ) executed is determined by the type of object being
referred to at the time of the call. Had it been determined by the type of the reference variable, obj.

Class B extends A{
double k;
class A B() { }
B(int i, int j,int k){
{ double i,j; super(i,j);
A() { } this.k=k;
A(int i,int j){ }
void show()// this method overrides{
this.i=i;
System.out.println(“i=“+i+”j=“+j);
this.j=j; System.out.println(“k=“+k);
} }
void show(){ Public class Mainclass{
public static void main(String[] args){
System.out.println(“i=“+i+”j=“+j); A obj;
} obj= new A(10,20);
} obj.show();
obj=new B(1,2,3);
obj.show();
}
TOPIC 6
Polymorphism:

Polymorphism is essential to object-oriented programming for one reason: it allows a general class to specify
methods that will be common to all of its derivatives, while allowing subclasses to define the specific implementation
of some or all of those methods. Overridden methods allow Java to support run-time polymorphism.

Dynamic, run-time polymorphism is one of the most powerful mechanisms that object oriented
design brings to bear on code reuse and robustness.

In Java compile time polymorphism occurs through method overloading and dynamic polymorphism occurs when a
parent class reference is used to refer to a child class object.

Let’s look at a practical example that uses method overriding to achieve run_time polymorphism. The following
program creates a superclass called shape that stores the dimensions of a two-dimensional object. It also defines a
method called area( ) that computes the area of an object. The program derives two subclasses from Shape. The first
is Rectangle and the second is Triangle. Each of these subclasses overrides area( ) so that it returns the area of a
rectangle and a triangle respectively.
Run-Time polymorphism example
import java.io.*;
class Shape{ Class Rectangle extend Shape
double Dim1,Dim1; { Rectangle(double d1, double d2){
Shape(){} super(d1,d2);
}
Shape(double d1, double d2){
void computeArea() {
Dim1=d1;
a= Dim1*Dim2;
Dim2=d2;
System.out.println(a);
} }
void computeArea(){ }//rectangle close
System.out.println(“Hai ,I am shape class”); public class Mainclass{
}}// END OF Shape public static void main(String[] args){
class Triangle extends Shape{ Shape sh;
double a; sh=new Triangle(20.5.22.56);
Triangle(double d1,double d2){
sh.computeArea();
Super(d1, d2);
} sh=new Rectangle(23.45,.76,54);
void computeArea() { sh.computeArea();
a= 0.5*Dim1*Dim2; }
System.out.println(a); }
}
}// END OF Triangle
TOPIC 7
Abstract classes and Abstract methods
An abstract class is a class that cannot be instantiated, but they can be sub classed. An abstract method is a
method that is declared without an implementation.
An abstract method is declared like this:
abstract returntype methodname(Parameterlist);
An abstract class is declared like this:
accessmodifier abstract className {
// declare fields
// declare abstract methods
//define non abstract methods
}
If a class includes abstract methods, then the class itself must be declared as abstract. Abstract classes
provide partial implementation.
We use abstract classes if any of these statements apply to your situation:
You want to share base code among several closely related classes.
If certain methods of class need to be made it as a abstract .
 You expect that classes that extend your abstract class have many common methods or fields, or require
access modifiers other than public (such as protected and private)
--
abstract Employee
Empno
Name
Employee()
diplayEmpData()
abstract calculateSalary()

Contract_Based_Employee
Monthly_Based_Employee
Basicpay NoOfHours,wage
HRA
DA
Contract_Based_Employee(---------
Monthly_Based_Employee(------ --)
-) calculateSalary()
calculateSalary()
import java.util.Scanner; class CBEmployee extends Employee
abstract class Employee{ { double Nohours,hourlyWage, Netsalary;
private int Empno; private String Name; CBEmployee(int eno, String Name, double NH, double HW){
Employee(int Empno, String Name){ super(eno, Name);
this.Empno=Empno; this.Name=Name; Nohours=NH;
} hourlyWage=HW;
void displayEmpData(){ }
System.out.println("Employee no"+Empno); void calculateSalary(){
System.out.println("Name"+Name); Netsalary=Nohours*hourlyWage;
} }
abstract void calculateSalary(); void CBdisplay(){
}//EMP CLASS CLASE displayEmpData();
class MBEmployee extends Employee System.out.println("Total salary"+Netsalary);
{ double BasicPay, Netsalary; }
MBEmployee(int eno, String name, double bp){ }// CBEmployee close
super(eno,name); BasicPay=bp;
} public class AbstractDemo{
void calculateSalary(){ public static void main(String[] args){
if(BasicPay>=10000) MBEmployee ME=new MBEmployee(101,”KAPIL”, 20000);
Netsalary=BasicPay+(BasicPay*20/100.0) +(BasicPay*50/100.0) CBEmployee CE=new CBEmployee(101, “LAYA”, 30,200);
- (BaiscPay*18/100.0) ME.calculateSalary();
else CE.calculateSalary();
Netsalary=BasicPay+(BasicPay*15/100.0) +(BasicPay*75/100.0) ME.MBdisplay();
- (BaiscPay*12/100.0) CE.CBdisplay();
} }
void MBdisplay(){ }
displayEmpData();
System.out.println("Employee no"+Netsalary);
}
}//MBEmployee close
TOPIC 8
Interface
Interface is a complete abstract class.
Using interface ;you can specify what a class must do, but not how it does it. Interfaces are syntactically similar to
classes, but they lack instance variables, and their methods are declared without any body.

In practice, this means that you can define interfaces that don’t make assumptions about how they are
implemented. Once it is defined, any number of classes can implement an interface. Also, one class can
implement any number of interfaces.

To implement an interface, a class must create the complete set of methods defined by the interface. However,
each class is free to determine the details of its own implementation. By providing the interface keyword, Java
allows you to fully utilize the “one interface, multiple methods” aspect of polymorphism.
An interface is defined much like a class. This is the general form of an interface:
access interface name {
return-type method-name1(parameter-list);
return-type method-name2(parameter-list);
type final-varname1 = value;
type final-varname2 = value;
// ...
return-type method-nameN(parameter-list);
type final-varnameN = value;
All methods in an interface are public abstract. All interface variables are public static final

Implementing Interfaces:
Once an interface has been defined, one or more classes can implement that interface. To implement an
interface, include the implements clause in a class definition, and then create the methods defined by the
interface. The general form of a class that includes the implements clause looks like this:

class classname [extends superclass] [implements interface [,interface...]] {


// class-body

Example:
interface Geometry
{
double PI=3.14;
void computeArea();
void computePeri();
}
Example program:
interface Geometry public void computePeri(){
{ double PI=3.14;
void computeArea(); double p;
void computePeri(); p=2*PI*Radius;
} System.out.println(p);
Class Circle implements Geometry }
{double Radius; }
Circle(double d1) class ITest{
{ Radius=d1; public static void main(String[]
} args){
@Override
public void computearea() Circle C1=new Circle(12.5)
{double a; C1.computeArea();
a=PI*Radius*Radius; C1.computerPeri();
System.out.println(a); }
} }
Example 2:
interface Bicycle {
void changeCadence(int newValue);
void changeGear(int newValue);
}
class ACMEBicycle implements Bicycle {
int cadence = 0;
int gear = 1;
void changeCadence(int newValue) {
cadence = newValue;
}
void changeGear(int newValue) {
gear = newValue;
}
}
Topic 9:
Interfaces Can Be Extended
One interface can inherit another by use of the keyword extends. The syntax is the same as for inheriting classes.
When a class implements an interface that inherits another interface, it must provide implementations for all
methods defined within the interface inheritance chain. Following is an example:
class MyClass implements B {
public void meth1() {
System.out.println("Implement meth1().");
// One interface can extend another. }
interface A { public void meth2() {
void meth1(); System.out.println("Implement meth2().");
void meth2(); }
} public void meth3() {
// B now includes meth1() and meth2() -- it adds System.out.println("Implement meth3().");
meth3(). }
}
interface B extends A {
class IFExtend {
void meth3(); public static void main(String arg[]) {
} MyClass ob = new MyClass();
ob.meth1();
ob.meth2();
ob.meth3();
}
}
More suitable example to illustrate extension of another interface
interface A{
// declaration of interface A BankSpecifications
Methods getBalance()
} deposit()
withdraw()
interface B extends A{ computeInterestAndUpdateBalance()
// declaration of interface B
Methods
} PBSpecifications extends BankSpecifications
add20percenttoBalance()
class C implements B{
// implementation of all //
methods
}
SBI
SARADABan
interface BankSpecifications{ class NewBank implements PBSpecifications{
double getBalance();
void deposit(double amt);
void withdraw(double amt); double balance;
void computeInterestAndUpdateBalance(double irate); NewBank(){ balance=0;}
}
}
public void deposit(double amt){
interface PBSpecifications extends BankSpecifications{
void add20percenttoBalance(); balance=balance+amt;
}
}
class SBI implements BankSpecifications{
double balance; public void withdraw(double amt){
SBI(){ balance=0;}
public void deposit(double amt){ if(balance - amt >=0)
balance=balance+amt; balance=balance-amt;
} else
public void withdraw(double amt){ System.out.println("Insufficient balance");
if(balance - amt >=5000) }
balance=balance-amt; public void computeInterestAndUpdateBalance(double
else irate){
System.out.println("Insufficient balance");
}
balance=balance+(irate*balance)/100;
public void computeInterestAndUpdateBalance(double irate){ }
balance=balance+(irate*balance)/100; @Override
}
public double getBalance(){
public void add20percenttoBalance(){
return balance; balance=balance+(20*balance)/100;
}
}
}
public double getBalance(){
return balance;
}
}
class DMTest{
public static void main(String[] args){

SBI S=new SBI();


NewBank SB=new NewBank();

S.deposit(5000);
System.out.println(S.getBalance());
S.withdraw(2000);
System.out.println(S.getBalance());

SB.deposit(5000);
System.out.println(SB.getBalance());

SB.withdraw(2000);
System.out.println(SB.getBalance());

SB.add20percenttoBalance();
System.out.println(SB.getBalance());
}
}
TOPIC 10:
inheritance in Java by interface

In Java a class can implements multiple interfaces, or an interface extends multiple interfaces .

//Simple example to illustrate


interface Printable{
void print();
}
interface Showable{
void show();
}
class A7 implements Printable,Showable{
public void print(){System.out.println("Hello");}
public void show(){System.out.println("Welcome");}

public static void main(String args[]){


A7 obj = new A7();
obj.print();
obj.show();
}
}
Multiple inheritance using interfaces Example 2
MULTIPLE INHERITNCE IMPLEMENTATION WITH INTERFACES
interface Academic{
void computeAcademicTotal();
}
interface NonAcademic{ public void finalTotal(){
void setNonAcademicScore(double score); Ftotal=.75*Atotal+.25*Nascore;
} }
class Result implements Academic, NonAcademic{
int Sno; void display(){
double sub1; System.out.println("Rollno ="+Sno);
double sub2; System.out.println("Final Total ="+Ftotal);
double Atotal, Nascore,Ftotal; }
Result(int Sno,double s1, double s2){ }
this.Sno=Sno; class MIHTest{
sub1=s1; public static void main(String[] args){
sub2=s2;
} Result R=new Result(101, 70, 60);
@Override R.computeAcademicTotal();
public void computeAcademicTotal(){ R.setNonAcademicScore(90);
Atotal=sub1+sub2; R.finalResult();
} R.display();
@Override }
public void setNonAcademicScore(double score){ }
Nascore=score;
}
TOPIC 11:Interface with default methods
Default methods enable us to add new functionality to the existing interfaces of and ensure binary compatibility with code written for older
versions of those interfaces.
Consider the following interface for Bank:
interface BankSpecifications{
double getBalance();
void deposit(double amt);
void withdraw(double amt);
void computeInterestAndUpdateBalance(double irate);
}
One possible implementation of the above interface is as follows:

class SBI implements BankSpecifications{


double balance;
SBI(){ balance=0;}
public void deposit(double amt){
balance=balance+amt;
}
public void withdraw(double amt){
if(balance - amt >=5000)
balance=balance-amt;
else
System.out.println("Insufficient balance");
}
public void computeInterestAndUpdateBalance(double irate){
balance=balance+(irate*balance)/100;
}
public double getBalance(){
return balance;
}
}
Suppose that you want to add new functionality to the BankSpecifacations interface, say a NewBank would like to add 20%
to the existing balance if the customer do regular transactions for 1 year. One way to achieve this is by modifying existing
interface. The resultant interface might be like this:

interface BankSpecifications{
double getBalance();
void deposit(double amt);
void withdraw(double amt);
void computeInterestAndUpdateBalance(double irate);
void add20percenttoBalance()
}
Following this modification to the BankSpecifications interface, you would also have to modify the class SBI and SBI need to
implement the add20percenttoBalance() also . However, usually existing classes does not react to interface modifications. In
that situation , you can instead define a default implementation. (Remember that an abstract method is a method declared
without an implementation.).The following is the BankSpecifications interface with default methods:
interface BankSpecifications{
double getBalance();
void deposit(double amt);
void withdraw(double amt);
void computeInterestAndUpdateBalance(double irate);
default void add20percenttoBalance(){
System.out.println("It adds 20percent to the existing balance ");
System.out.println("if account holder continue minimum number of transactions in the current year");
}
}
Demonstration of default methods
interface BankSpecifications{ class NewBank implements BankSpecifications{
double getBalance();
void deposit(double amt);
void withdraw(double amt); double balance;
void computeInterestAndUpdateBalance(double irate); NewBank(){ balance=0;}
default void add20percenttoBalance(){
System.out.println("It adds 20percent to the existing balance ");
public void deposit(double amt){
System.out.println("if account holder continue minimum number
of transactions in the current year"); balance=balance+amt;
}
}
}
class SBI implements BankSpecifications{ public void withdraw(double amt){
double balance;
SBI(){ balance=0;} if(balance - amt >=0)
public void deposit(double amt){
balance=balance-amt;
balance=balance+amt; else
} System.out.println("Insufficient balance");
public void withdraw(double amt){
}
if(balance - amt >=5000) public void computeInterestAndUpdateBalance(double
balance=balance-amt; irate){
else
System.out.println("Insufficient balance");
balance=balance+(irate*balance)/100;
} }
public void computeInterestAndUpdateBalance(double irate){ @Override
balance=balance+(irate*balance)/100;
}
public void add20percenttoBalance(){
public double getBalance(){ balance=balance+(20*balance)/100;
return balance;
}
}
}
public double getBalance(){
return balance;
}
}
class DMTest{
public static void main(String[] args){

SBI S=new SBI();


SARADABank SB=new NewBank();

S.deposit(5000);
System.out.println(S.getBalance());
S.withdraw(2000);
System.out.println(S.getBalance());

SB.deposit(5000);
System.out.println(SB.getBalance());

SB.withdraw(2000);
System.out.println(SB.getBalance());

SB.add20percenttoBalance();
System.out.println(SB.getBalance());
}
}
TOPIC 12: Methods: class BB implements A{
In addition to default methods, you can define static @Override
methods in interfaces. (A static method is a method that is
associated with the class in which it is defined rather than
public void printName(String s){
with any object. Every instance of the class shares its if (!A.isNull(s))
static methods.) This makes it easier for you to organize System.out.println(s);
helper methods in your libraries; you can keep static else
methods specific to an interface in the same interface System.out.println("Sorry given string is null");
rather than in a separate class. The following is an }
example @Override
public void printNumber(int n){

interface A{ System.out.println(n);
static boolean isNull(String s){ }
return s==null?true:false; }
} class SMTest{
void printName(String s); public static void main(String[] args){
BB obj=new BB();
void printNumber(int n); String str=null;
} obj.printName(str);
obj.printNumber(10);
}
TOPIC 13:
Has-A (Association) :
In Object orientation design, We can say “class B is in Has-A relationship
with class A if class B holds reference of class A”.

By this reference of class A, B can access all properties of class A which


are allowed.

Example :
Class A
class HardDisk {
public void writeData(String data) {
System.out.println("Data is being written : " + data);
} HAS-A
}
Class B
class Dell {
// Dell Has-A HardDisk

HardDisk H= new HardDisk();


public void save (String data) {
H.writeData(data);
}
}
Aggregation v/s Composition :

Has-A relationship or Association can be divided in two types :


-1.Aggregation
-Composition
Aggregation :

Consider above example : HardDisk class and Dell class.


In the example, Dell HAS-A HardDisk

If Laptop stops working somehow, you can remove hard disk from that and connect to other laptop, This is Aggregatio
In aggregation container class (Dell) and referenced class (HardDisk) can have their independent existence.

Composition :
Now for Composition, consider two different class House and Kitchen.
class House { Kitchen kitchen = new Kitchen(); // More code for House class. }
class Kitchen { // code of Kitchen class. }

If House gets destroyed Kitchen also will be destroyed with that House, This is composition.
In composition reference class (Kitchen) can not exist if container class (House) gets destroyed.
TOPIC 14:
Final Keyword In Java

Final keyword can be used in three cases


1) final variable
2) final method
3) final class

final variable
Final variables are nothing but constants. We cannot change the value of a final variable once it is initialized. Lets
have a look at the below code:In this program MAX_VALUE is the final variable.

class Demo{

final int MAX_VALUE=99;


void myMethod(){
System.out.pritln(MAX_VALUE);
}
public static void main(String args[]){
Demo obj=new Demo();
obj.myMethod();
}
}
final method
A final method can be inherited but cannot be overridden. Which means, even though a sub class can call the
final method of parent class without any issues but it cannot override it.

Example:

class XYZ{
final void demo(){
System.out.println("XYZ Class Method");
}
}

class ABC extends XYZ{


void demo(){
System.out.println("ABC Class Method");
}
public static void main(String args[]){
ABC obj= new ABC();
obj.demo();
}
}
Output: demo() in ABC cannot override demo() in XYZ
The above program would throw a compilation error, however we can use the parent class final method in sub
class without any issues.

The following program would run fine as we are not overriding the final method. That shows that final methods
are inherited but they are not eligible for overriding.

class XYZ{
final void demo(){
System.out.println("XYZ Class Method");
}
}

class ABC extends XYZ{


public static void main(String args[]){
ABC obj= new ABC();
obj.demo();
}
}
Output:
final class
We cannot extend a final class. Consider the below example:

final class XYZ{


}

class ABC extends XYZ{


void demo(){
System.out.println("My Method");
}
public static void main(String args[]){
ABC obj= new ABC();
obj.demo();
}
}
Output:

The type ABC cannot subclass the final class XYZ


Topic 15: Packages
A package is a collection of related Java entities (such as classes, interfaces, exceptions, errors and enums).
Packages are used for:
Resolving naming conflict of classes by prefixing the class name with a package name. For example, com.zzz.
Circle and com.yyy.Circle are two distinct classes. Although they share the same class name Circle, but they belong to two
different packages: com.zzz and com.yyy. These two classes can be used in the same program and distinguished using
the fully-qualified class name - package name plus class name. This mechanism is called Namespace Management.
Access Control: Besides public and private, Java has two access control modifiers – protected and default – that are related
to package. A protected entity is accessible by classes in the same package and its subclasses. An entity without access
control modifier (i.e., default) is accessible by classes in the same package only.
For distributing a collection of reusable classes, usually in a format known as Java Archive (JAR) file.
Package Name & the Directory Structure
The package name is closely associated with the directory structure used to store the classes. The classes (and other
entities) belonging to a specific package are stored together in the same directory. Furthermore, they are stored in a sub-
directory structure specified by its package name. For example, the class Circle of package com.zzz.project1.subproject2 is
stored as
"$BASE_DIR\com\zzz\project1\subproject2\Circle.class", where $BASE_DIR denotes the base directory of the package.
Clearly, the "dot" in the package name corresponds to a sub-directory of the file system.

The base directory ($BASE_DIR) could be located anywhere in the file system. Hence, the Java compiler and runtime must
be informed about the location of the $BASE_DIR so as to locate the classes. This is accomplished by an environment
variable called CLASSPATH. CLASSPATH is similar to another environment variable PATH, which is used by the command
shell to search for the executable programs.

Creating Packages
To make a class as part of a package, you have to include the package statement as the first statement in the source file.
Example 1
We shall write a class called Circle in package yyy. It is a good practice to store the source codes and the classes in
separate directories, to facilitate the distribution of classes without the source codes. Suppose that we save the
source as d:\myJavaProject\src\yyy\Circle.java, and the compiled class as d:\myJavaProject\classes\yyy\Circle.
class. Let's write the source as follows:

// d:\myJavaProject\src\yyy\Circle.java
package yyy;
public class Circle {
private double radius;
public Circle(double radius) {
this.radius = radius;
}
public double area() {
return 3.414*radius*radius;
}
}
To compile the source using JDK, we need to use the -d option to specify the package base directory of the
compiled class d:\myJavaProject\classes as follows (-d defaulted to the current directory):
> javac -d d:\myJavaProject\classes d:\myJavaProject\src\yyy\Circle.java
The compiled class will be kept in d:\myJavaProject\classes\yyy\Circle.class. Directory "yyy" will be created
automatically. Instead of absolute path, we could also use relative path.
Let's write a test program to use this Circle class. Suppose that TestCircle.java is saved in d:\myOtherProject.
// d:\myOtherProject\TestCircle.java
import yyy.Circle;
public class TestCircle {
public static void main(String[] args) {
Circle c = new Circle(1.23);
System.out.println(c.area());
}
}
If we compile TestCircle.java from the directory d:\myOtherProject, we will get a error message, as the compiler
cannot find the yyy.Circle class.
d:> cd \myOtherProject

d:\myOtherProject> javac TestCircle.java


TestCircle.java:1: package yyy does not exist
import yyy.Circle;
^
We need to use the -cp (or -classpath) option to specify the base directory of the package yyy, in order to locate yyy.
Circle.
d:\myOtherProject> javac -cp d:\myJavaProject\classes TestCircle.java
To run the TestCircle, we again get a error, as JRE cannot find the yyy.Circle.
d:\myOtherProject> java TestCircle
Exception in thread "main" java.lang.NoClassDefFoundError: yyy/Circle
Let include the base directory of the package yyy in the classpath (to locate yyy.Circle):
d:\myOtherProject> java -cp d:\myJavaProject\classes TestCircle
Exception in thread "main" java.lang.NoClassDefFoundError: TestCircle
CLASSPATH - For Locating Classes
CLASSPATH is an environment variable needed for the Java compiler and runtime to locate the Java
packages used in a Java program

CLASSPATH can be set in one of the following ways:


1. CLASSPATH can be set permanently in the environment: In Windows, choose control panel ⇒ System ⇒
Advanced ⇒ Environment Variables ⇒ choose "System Variables" (for all the users) or "User Variables" (only
the currently login user) ⇒ choose "Edit" (if CLASSPATH already exists) or "New" ⇒ Enter "CLASSPATH" as
the variable name ⇒ Enter the required directories e.g., ".;c:\javaproject\classes; Take note that you need to
include the current working directory (denoted by '.') in the CLASSPATH.
2. CLASSPATH can be set temporarily for that particular CMD shell session by issuing the following command:
SET CLASSPATH
3. Instead of using the CLASSPATH environment variable, you can also use the command-line option -
classpath or -cp of the javac and java commands, for example,

You might also like