KEMBAR78
Inheritance, Abstract and Package | PDF | Method (Computer Programming) | Computers
0% found this document useful (0 votes)
70 views84 pages

Inheritance, Abstract and Package

What is Inheritance, Abstract and package in java

Uploaded by

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

Inheritance, Abstract and Package

What is Inheritance, Abstract and package in java

Uploaded by

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

Inheritance and

Abstract Class
Inheritance
• Inheritance is an important feature of OOP.
• Inheritance is a mechanism in which one class acquires all the properties
and behaviors of a parent class.
• extends keyword used for inheritance. Super-
class
• A class that is inherited is called a superclass.
• The class that inherits the other class is called a subclass. extends

• Therefore, a subclass is a specialized version of a superclass.


Sub-class
class subclass-name extends superclass-name
{
// body of class
}
Inheritance contt..
• The idea behind inheritance in Java is that you can create new classes that
are built upon existing classes. When you inherit from an existing class, you
can reuse methods and fields of the parent class. Moreover, you can add new
methods and fields in your current class also.
• Why use inheritance in java
• For Method Overriding (so runtime polymorphism can be achieved).
• For Code Reusability.
Inheritance example
class A { class B extends A {
int i=5, j=10; int k=100;
void showij() void showk()
{ {
System.out.println("k: " + k);
System.out.println("i and j: " + i + " " + j);
}
}
public static void main(String args []) {
} A superOb = new A();
B subOb = new B();
System.out.println("Method with super_Object: ");
A Generalization
showij() superOb.showij();
System.out.println("Method with sub_Object: ");
extends subOb.showij();
subOb.showk();
B showij()
Specialization
}
showk() }
Generalization and Specialization in
java
• General class?
• Loosely speaking, a class which tells the main features
but not the specific details. The classes situated at the
top of the inheritance hierarchy can be said as General.
• Specific class?
• A class which is very particular and states the specific
details. The classes situated at the bottom of the
inheritance hierarchy can be said as Specific
Inheritance (Rules)
• We can only specify one superclass for any subclass.
• Java does not support the inheritance of multiple super-classes into a
single subclass.
• But it is possible that we can create a hierarchy of inheritance in
which a subclass becomes a superclass of another subclass.
• However, no class can be a superclass of itself.
• The inherited fields can be used directly, just like any other fields.
• Although a subclass includes all of the members of its superclass, it
cannot access those members of the superclass that have been
declared as private.
• A class member that has been declared as private will remain private
to its class. It is not accessible by any code outside its class, including
subclasses.
Types of Inheritance
•Single Inheritance:
•Multilevel Inheritance:
•Multiple Inheritance
•Hybrid Inheritance
Inheritance Supported by class in
Java
When one class inherits multiple
classes, it is known as multiple
inheritance.
Example

The relationship between the two classes


is Programmer IS-A Employee. It means that
Programmer is a type of Employee.
Example Contt..
class Employee{
float salary=40000;
}
class Programmer extends Employee{
int bonus=10000;
public static void main(String args[]){
Programmer p=new Programmer();
System.out.println("Programmer salary is:"+p.salary);
System.out.println("Bonus of Programmer is:"+p.bonus);

}
}
Single Inheritance in java
class Animal
{
void eat()
{ Animal
System.out.println("eating...");}
}
class Dog extends Animal
{
void bark()
{
System.out.println("barking...");}
} DOG
class TestInheritance
{
public static void main(String args[])
{
Dog d=new Dog();
d.bark();
d.eat();
}}
Multilevel Inheritence
class Animal
{
void eat(){System.out.println("eating..."); Animal
}
}
class Dog extends Animal
{
void bark(){System.out.println("barking...");}
}
class BabyDog extends Dog
DOG
{
void weep(){System.out.println("weeping...");}
}
class TestInheritance2
{
public static void main(String args[]){
BabyDog d=new BabyDog();
d.weep();
d.bark(); BabyDog
d.eat();
}
Hierarchical Inheritance Example
class Animal
{
void eat(){System.out.println("eating...");
}
Animal
}
class Dog extends Animal
{
void bark(){System.out.println("barking...");
}
}
class Cat extends Animal
{
DOG CAT
void meow(){System.out.println("meowing...");
}
}
class TestInheritance3
{
public static void main(String args[]){
Cat c=new Cat();
c.meow();
c.eat();
//c.bark();//C.T.Error
}}
Q) Why multiple inheritance is not
supported in java?
• To reduce the complexity and simplify the language,
multiple inheritance is not supported in java.
• Consider a scenario where A, B, and C are three
classes. The C class inherits A and B classes. If A and
B classes have the same method and you call it from
child class object, there will be ambiguity to call the
method of A or B class.
• Since compile-time errors are better than runtime
errors, Java renders compile-time error if you inherit 2
classes. So, whether you have same method or
different, there will be compile time error.
Output??
class A
{
void msg(){System.out.println("Hello");}
}
class B
{
void msg(){System.out.println("Welcome");}
}
class C extends A,B
{

Public Static void main(String args[])


{
C obj=new C();
obj.msg();
}
}
Access Modifiers in Java
• As the name suggests access modifiers in Java helps to
restrict the scope of a class, constructor, variable,
method, or data member. There are four types of access
modifiers available in java:
1.Default – No keyword required
2.Private
3.Protected
4.Public
Default Modifier
• Default: When no access /save by A.java
modifier is specified for a package pack;
class A{
class, method, or data void msg(){System.out.println("Hello");}
member – It is said to be }
having //save by B.java
the default access package mypack;
import pack.*;
modifier by default. class B{
• The data members, class public static void main(String args[]){
or methods which are not A obj = new A();//Compile Time Error
declared using any access obj.msg();//Compile Time Error
modifiers i.e. having }
default access modifier are }
accessible only within
the same package.
Protected
• The protected access /save by A.java
package pack;
modifier is accessible public class A{
within package and outside protected void msg()
{System.out.println("Hello");}
the package but through }
inheritance only. //save by B.java
package mypack;
• The protected access import pack.*;
modifier can be applied on
class B extends A{
the data member, method public static void main(String args[]){
and constructor. It can't be B obj = new B();
applied on the class. obj.msg();
}
• It provides more }
accessibility than the
Public

• The public access //save by A.java

modifier is accessible package pack;


everywhere. It has the public class A{
public void msg(){System.out.println("Hello");}
widest scope among all }
other modifiers. //save by B.java

package mypack;
import pack.*;

class B{
public static void main(String args[]){
A obj = new A();
obj.msg();
}
}
Private

• The private class A{


private int data=40;
access modifier is private void msg()
accessible only {System.out.println("Hello java");}
}
within the class.
public class Simple{
public static void main(String args[]){
A obj=new A();
System.out.println(obj.data);//
Compile Time Error
obj.msg();//Compile Time Error
}
}
A Superclass Variable Can Reference a Subclass Object
• A reference variable of a superclass can be assigned a reference to any
subclass derived from that superclass. class A {
class B extends A { int i=5, j=10;
int k=100; void showij()
void showk()
{
{
System.out.println("i and j: " + i + " " + j);
System.out.println("k: " + k);
} }
public static void main(String args []) { }
A superOb = new A();
A superRef = new B();
System.out.println("Method with super_Object: ");
superOb.showij();
System.out.println("Method with super_Reference : ");
superRef.showij();
superRef.showk();
}
A Superclass Variable Can Reference a Subclass Object
• When a reference to a subclass object is assigned to a superclass
reference variable, you will have access only to those parts of the
object defined by the superclass.
• This is why superRef can’t access showk() even when it refers to a
sub-class object. If you think about it, this makes sense, because the
superclass has no knowledge of what a subclass adds to it.
Super keyword in java

• The super keyword in java is a reference variable


which is used to refer immediate parent class object.
• Whenever you create the instance of subclass, an
instance of parent class is created implicitly which is
referred by super reference variable.
• Usage of java super Keyword
1.super can be used to refer immediate parent class instance
variable.
2.super can be used to invoke immediate parent class
method.
3.super() can be used to invoke immediate parent class
constructor.
Using super
• super keyword has two general forms.
i. To access a member of the superclass
ii. To call the superclass constructor
• When a subclass needs to refer to its immediate superclass, it can do
so by use of the keyword super.
super.member
• Here, member can be either a method or an instance variable.
• super is most applicable to situations in which member names of a
subclass hide members by the same name in the superclass.
Using super
• Example:
class A {
int i=5;
}

class B extends A {
int i=100;
void show()
{
System.out.println("i in superclass: " + super.i);
System.out.println("i in subclass: " + i);
}
public static void main(String args []) {
B superRef = new B();
superRef.show();
}
}
Using super
• Example:
class A {
int i=5;
}

class B extends A {
int i=100;
void show()
{
System.out.println("i in superclass: " + super.i);
System.out.println("i in subclass: " + i); Output:
} i in superclass: 5
public static void main(String args []) { i in subclass: 100
B subRef = new B();
subRef.show();
}
}
Method Overriding
• 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.

• We can also specify @Override annotation before the


method that is going to override for more clarity.
Method Overriding
class A { class B extends A {
void show () @Override
{ void show()
System.out.print("show() in super class"); {
} System.out.print("show() in sub class");
} }
public static void main(String args []) {
B subOb = new B();
subOb.show();
}
}
Method Overriding
class A { class B extends A {
void show () void show()
{ {
System.out.print("show() in super class"); System.out.print("show() in sub class");
} }
} public static void main(String args []) {
B subOb = new B();
subOb.show();
}
}

Output:
show() in sub class
Method Overriding
• In the example, the version of show( ) inside B overrides the version
declared in A.
• If you wish to access the superclass version of an overridden method,
you can do so by using super.
Method Overriding
class A { class B extends A {
void show () void show()
{ {
System.out.print("show() in super class"); super.show();
} System.out.print("show() in sub class");
} }
public static void main(String args []) {
B subOb = new B();
subOb.show();
}
}
Method Overriding
class A { class B extends A {
void show () void show()
{ {
System.out.print("show() in super class"); super.show();
} System.out.print("show() in sub class");
} }
public static void main(String args []) {
B subOb = new B();
subOb.show();
}
}
Output:
show() in super class
show() in sub class
Method Overriding
• Important points:
• The new method definition must have the same method signature, i.e.,
the method name, and the types and the number of parameters,
including their order, are the same as in the overridden method.
• The return type of the overriding method can be a subtype of the return
type of the overridden method (called covariant return).

• Can we change method signature in overriding in Java?


• Answer=No: if we change the signature, you cannot override
the super class’s method if you try the method of the
super class will be executed.
class A{
A get(){return this;}
}
class B1 extends A{
@Override
B1 get(){return this;}
void message()
{
System.out.println("welcome to covariant return type");}

public static void main(String args[]){


B1 b =new B1()
b.get();
b.message();
}}
Example (Overriding method Signature
Change)
class Super {
void sample(int a, int b) {
System.out.println("Method of the Super
class");
}}
public class MethodOverriding extends Super {
void sample(int a, float b) {
System.out.println("Method of the Sub class");
}
public static void main(String args[]) {
MethodOverriding obj = new
MethodOverriding();
Method Overriding
A Superclass Variable Can Reference a Subclass Object: 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.
• It is the type of the object being referred to (not the type of the
reference variable) that determines which version of an overridden
method will be executed.
• If a superclass contains a method that is overridden by a subclass,
then when different types of objects are referred to through a
superclass reference variable, different versions of the method are
executed.
• Dynamic Method Dispatch

• It 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 this concept 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
• When different types of objects are referred to, different
versions of an overridden method will be called.
09/23/2024 40
Dynamic Method Dispatch (Method Overriding)
class A { class C extends B {
void show () void show()
{ {
System.out.println("show() in A class"); System.out.println("show() in C class");
} }
} public static void main(String args []) {
A a = new A();
class B extends A{ B b = new B();
void show () C c = new C();
{ A r;
System.out.println("show() in B class"); r = a;
} r.show();
r = b;
} r.show();
r = c;
r.show();
}}
Dynamic Method Dispatch (Method Overriding)
class A { class C extends B {
void show () void show()
{ {
System.out.println("show() in A class"); System.out.println("show() in C class");
} }
} public static void main(String args []) {
A a = new A();
class B extends A{ B b = new B();
void show () C c = new C();
{ A r;
System.out.println("show() in B class"); r = a;
} r.show();
r = b;
} Output: r.show();
show() in A class r = c;
show() in B class r.show();
show() in C class
}}
Advantages of Dynamic Method
Dispatch
1.Dynamic method dispatch allow Java to
support overriding of methods which is central for run-
time polymorphism.
2.It allows a 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.
3.It also allow subclasses to add its specific methods
subclasses to define the specific implementation of some.
Comparison Method Overriding vs
Overloading
Method Overriding Method Overloading
Implements “runtime polymorphism” Implements “compile time polymorphism”

The method call is determined at runtime The method call is determined at compile
based on the object type time

Occurs between the methods in the same


Occurs between superclass and subclass class

Have the same signature (name and method Have the same name, but the parameters
arguments) are different

On error, the effect will be visible at runtime On error, it can be caught at compile time
Return type should be same Its not depends on return type.
Abstraction in Java

• Abstraction is a process of hiding the implementation details and


showing only functionality to the user.
• Another way, it shows only essential things to the user and hides the
internal details, for example, sending SMS where you type the text and
send the message. You don't know the internal processing about the
message delivery.
• Abstraction lets you focus on what the object does instead of how it
does it.
• Ways to achieve Abstraction
There are two ways to achieve abstraction in java
• Abstract class (0 to 100%)
• Interface (100%)
Abstract class in Java

• A class which is declared with the abstract keyword is


known as an abstract class in Java. It can have abstract and
non-abstract methods (method with the body).
• It needs to be extended and its method implemented. It cannot be
instantiated.
Points to Remember
• An abstract class must be declared with an abstract keyword.
• It can have abstract and non-abstract methods.
• It cannot be instantiated.
• It can have constructors and static methods also.
• It can have final methods which will force the subclass not to
change the body of the method.
Example of abstract class
abstract class A{}
abstract class Bike
{
abstract void run();
}
class Honda4 extends Bike
{
void run()
{
System.out.println("running safely");
}
public static void main(String args[])
{
Bike obj = new Honda4();
obj.run();
}
}
Abstract Class Abstract
Method

Double_click();
Mouse

Mycomp Mydoc NewFolder MyFolder


Mouse M= new Mouse(); X
Abstract Class Abstract
Method
Mouse M= new Mycomp();
M.double_click(); double_click();
Mouse

Mycomp Mydoc NewFolder MyFolder


package abstractkey; class Triangle extends Figure {
abstract class Figure { Triangle(double a, double b) {
double dim1; super(a, b);
double dim2; }
Figure(double a, double b) { double area() {
dim1 = a; System.out.println("Inside Area for
dim2 = b; Triangle.");
} return dim1 * dim2 / 2;
abstract double area(); // }
Abstract method }
} class AbstractAreas {
class Rectangle extends Figure { public static void main(String args[]) {
Rectangle(double a, double b) { Rectangle r = new Rectangle(9, 5);
super(a, b); Triangle t = new Triangle(10, 8);
} Figure figref; // this is OK, no object is
double area() { created
System.out.println("Inside Area for figref = r;
Rectangle."); System.out.println("Area is " +
return dim1 * dim2; figref.area());
} figref = t;
} System.out.println("Area is " +
figref.area());
}
package abstractkey; class Triangle extends Figure {
abstract class Figure { Triangle(double a, double b) {
double dim1; super(a, b);
double dim2; }
Figure(double a, double b) { double area() {
dim1 = a; System.out.println("Inside Area for
dim2 = b; Triangle.");
} return dim1 * dim2 / 2;
abstract double area(); // }
Abstract method }
} class AbstractAreas {
class Rectangle extends Figure { public static void main(String args[]) {
Rectangle(double a, double b) { Rectangle r = new Rectangle(9, 5);
super(a, b); Triangle t = new Triangle(10, 8);
} Figure figref; // this is OK, no object is
double area() { created
System.out.println("Inside Area for figref = r;
Rectangle."); System.out.println("Area is " +
return dim1 * dim2; figref.area());
} figref = t;
} System.out.println("Area is " +
figref.area());
}
Abstract Classes Properties
• A class with one or more abstract methods is automatically abstract
and it cannot be instantiated.
• A class declared abstract, even with no abstract methods can not be
instantiated.
• A subclass of an abstract class can be instantiated if it overrides all
abstract methods by implementing them.
• A subclass that does not implement all of the superclass abstract
methods is itself abstract; and it cannot be instantiated.
• Although abstract classes cannot be used to instantiate objects, they
can be used to create object references
• it must be possible to create a reference to an abstract class so that it
can be used to point to a subclass object.

09/23/2024 53
Using final to Prevent
Overriding
• While method overriding is one of Java’s most powerful features, there will be times
when you will want to prevent it from occurring. To disallow a method from being
overridden, specify final as a modifier at the start of its declaration. Methods
declared as final cannot be overridden.
class A {
final void meth() {
System.out.println("This is a final method.");
}
}
class B extends A {
void meth() { // ERROR! Can't override.
System.out.println("Illegal!");
}
}
Because meth( ) is declared as final, it cannot be overridden in B. If you attempt to
Using final to Prevent Inheritance
Sometimes you will want to prevent a class from being inherited. To do this, precede the
class declaration with final. Declaring a class as final implicitly declares all of its methods
as final, too. As you might expect, it is illegal to declare a class as both abstract and final
since an abstract class is incomplete by itself and relies upon its subclasses to provide
complete implementations.
final class A {
• //...
• }
• // The following class is illegal.
• class B extends A { // ERROR! Can't subclass A
• //...
• }
• As the comments imply, it is illegal for B to inherit A since A is declared as final.
Interfaces
• Interface is a conceptual entity similar to a Abstract class.
• using interface, you can specify what a class must do, but not how it
does it.
• Can contain only constants (final variables) and abstract method (no
implementation) - Different from Abstract classes.
• Use when a number of classes share a common interface.
• Each class should implement the interface.
• Any number of classes can implement an interface.
• One class can implement any number of interfaces
• Interfaces are designed to support dynamic method resolution at run
time

09/23/2024 56
• A class can implement any number of interfaces but cannot
extend more than one class at a time.
• Therefore, interfaces are considered as an informal way of
realizing multiple inheritance in Java.
• Access modifier is either public or default
• All methods and variables are implicitly public if the interface,
itself, is declared as public

09/23/2024 57
Interface - Example
<<Interface>>
Speaker
speak()

Politician Priest Lecturer


speak() speak() speak()

09/23/2024 58
Interfaces Definition
• Syntax (appears like abstract class):
interface InterfaceName {
// Constant/Final Variable Declaration
// Methods Declaration – only abstract
method
• Example: }

interface Speaker {
public void speak( );
}

09/23/2024 59
Implementing Interfaces
• Interfaces are used like super-classes whose properties are inherited by
classes.
• 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:
class ClassName implements InterfaceName [, InterfaceName2, …]
{
// Body of Class
}
• If a class implements more than one interface, the interfaces are separated
with a comma
• The methods that implement an interface must be declared public

09/23/2024 60
Implementing Interfaces Example
class Politician implements Speaker {
public void speak(){
System.out.println(“Talk politics”);
}
}
class Priest implements Speaker {
public void speak(){
System.out.println(“Religious Talks”);
}
}
class Lecturer implements Speaker {
public void speak(){
System.out.println(“Talks Object Oriented Design and
Programming!”);
}
}
09/23/2024 61
• Partial Implementations
• If a class includes an interface but does not fully implement the methods defined by
that interface, then that class must be declared as abstract.
• Extending Interfaces
• Like classes, interfaces can also be extended.
• This is achieved by using the keyword extends as follows:

interface InterfaceName2 extends


InterfaceName1 {
// Body of InterfaceName2
}

09/23/2024 62
// One interface can extend another.
public void meth3() {
interface A {
System.out.println("Implement meth3().");
void meth1();
}
void meth2();
} }
// B now includes meth1() and meth2() — it adds class IFExtend {
meth3(). public static void main(String arg[]) {
interface B extends A { MyClass ob = new MyClass();
void meth3(); ob.meth1();
} ob.meth2();
// This class must implement all of A and B ob.meth3();
class MyClass implements B {
}
public void meth1() {
}
System.out.println("Implement meth1().");
}
public void meth2() {
System.out.println("Implement meth2().");
}

09/23/2024 63
Inheritance and Interface Implementation

• A general form of interface implementation:


class ClassName extends SuperClass implements InterfaceName [,
InterfaceName2, …]
{
// Body of Class
}

• This shows a class can extended another class while implementing one or more
interfaces. It appears like a multiple inheritance (if we consider interfaces as
special kind of classes with certain restrictions or special features).

09/23/2024 64
Example Interface
interface Bank{
float rateOfInterest();
}
class SBI implements Bank{
public float rateOfInterest()
{return 9.15f;}
}
class PNB implements Bank{
public float rateOfInterest()
{return 9.7f;}
}
class TestInterface2{
public static void main(String[] args){
Bank b=new SBI();
System.out.println("ROI: "+b.rateOfIntere
Multiple Inheritance using
Interface
interface Printable{
void print();
} Printable Showable
interface Showable{
void show();
}
class A7 implements Printable,Showable{
A7

public void print()


{System.out.println("Hello");} Multiple Inheritance
public void show()
{System.out.println("Welcome");}

public static void main(String args[]){


A7 obj = new A7();
obj.print();
Polymorphism
• The term polymorphism literally means "having many forms“
• also called dynamic binding or late binding or run-time binding
• allows to create versatile software designs
• In OOP, polymorphism promotes code reuse by calling the method
in a generic way.
• Suppose we create the following reference variable:
Animal myPets;
• Java allows this reference to point to an Animal object, or to any
object of any compatible type
• This compatibility can be established using inheritance or using
interfaces
• Careful use of polymorphic references can lead to elegant, robust
software designs
References and Inheritance
• An object reference can refer to an object of its class, or to an object of
any class related to it by inheritance
• For example, if the Shape class is used to derive a class called
Circle, then a Shape reference could be used to point to a
Circle object
Shape

Shape s;
s = new Circle();
Circle

68
• Assigning a child object to a parent reference is considered to be a
widening conversion, and can be performed by simple assignment
• Assigning a parent object to a child reference can be done also, but it
is considered a narrowing conversion and must be done with a cast
• The widening conversion is the most useful

69
Polymorphism via
Inheritance
• It is the type of the object being referenced, not the reference type, that
determines which method is invoked
• Suppose the Shape class has a method called area, and the Circle
class overrides it
• Now consider the following invocation:
s.area();
• If s refers to a Shape object, it invokes the Shape version of area; if it
refers to a Circle object, it invokes the Circle version
Polymorphism
• Consider the following inheritance
Object Reference Conversion

• A polymorphic reference is a variable that can refer to


different types of objects at different points in time
• The method invoked through a polymorphic reference can
change from one invocation to the next
• All object references in Java are potentially polymorphic
Account account1;
...
account1 = new SAccount(“s123”,”Tom”, 100);
...
account1=new Account(“c123”,”Kim”,2000);
• To enable methods to be called in a polymorphic way Java
allows a superclass reference to refer to a subclass object.
• As SAccount and CAccount extend the class Account both
of these statements are valid.
Invoking methods through Superclass Reference

• When Account reference account1 referring to a


subclass object is used to invoke a method such as
withdraw(), the overridden withdraw() of that
subclassis invoked.
Account account1 = new
SAccount(“s123”,”Tom”,100);
account1.withdraw(100); // withdraw of SAccount
invoked account1 = new CAccount
(“c343”,”Kim”,2000);
account1.withdraw(200); // withdraw of CAccount
invoked
Use of Polymorphism

Account[] accounts = new Account[3];


accounts[0] = new Account("a12345", "Charles", 1000);
accounts[1] = new SAccount("s12346", "Craig", 1200);
accounts[2] = new CAccount("c12347", "George", 200);
// Deduct fixed amount $500 from all accounts
for (inti=0; i<3; i++)
accounts[i].withdraw(500);
Which withdraw() methods are called ?
Though accounts[i] is an Account reference in Java, actual method
called is determined at run-time based on the type of object being
referred.
Polymorphism via
Interfaces
• An interface name can be used as the type of an object
reference variable
Speaker current;
• The current reference can be used to point to any object of
any class that implements the Speaker interface
• The version of speak that the following line invokes
depends on the type of object that current is referencing
current.speak();
Polymorphism via
Interfaces
• Suppose two classes, Lecturer and Politician, both implement the
Speaker interface, providing distinct versions of the speak method
• In the following code, the first call to speak invokes one version and the
second invokes another:
Speaker guest = new lecturer();
guest.speak();
guest = new politician();
guest.speak();
Java Package

• A java package is a group of similar types of classes,


interfaces and sub-packages.
• Package in java can be categorized in two form, built-in
package and user-defined package.
• There are many built-in packages such as java, lang,
awt, javax, swing, net, io, util, sql etc.
Advantage of Java Package

1) Java package is used to


categorize the classes and
interfaces so that they can be
easily maintained. (reduce the
complexity of application components)
2) Java package provides
access protection.
3) Java package removes
naming collision. (Solves the
problem of unique class name conflict)
4)Software reuse
1.//save as Simple.java
2.package mypack;
3.public class Simple{
4. public static void ma
in(String args[]){
5. System.out.println("
Welcome to package");
6. }
7.}
How to access package from another package?

There are three ways to access the package from outside


the package.
import package.*; : all the classes and interfaces of this package will be
accessible but not subpackages. The import keyword is used to make the classes and
interface of another package accessible to the current package.

import package.classname; :If you import package.classname then only


declared class of this package will be accessible.

fully qualified name. : If you use fully qualified name then only
declared class of this package will be accessible. Now there is no need to import. But you
need to use fully qualified name every time when you are accessing the class or interface.
Import package example
1.//save by A.java 1.//save by A.java
2. 2.package pack;
3.package pack; 3.public class A{
4.public class A{ 4. public void msg()
5. public void msg() {System.out.println("Hello");}
{System.out.println("Hello");} 5.}
6.}
7.//save by B.java
8.package mypack; 6.//save by B.java
9.import pack.A; 7.package mypack;
10. 8.class B{
11.class B{ 9. public static void main(String args[]){
12. public static void main(String ar 10. pack.A obj = new pack.A();//
gs[]){ using fully qualified name
13. A obj = new A(); 11. obj.msg();
14. obj.msg(); 12. }
13.}
Example 2
// A simple package
package MyPack; class AccountBalance {
class Balance { public static void main(String
String name; args[]) {
double bal; Balance current[] = new
Balance(String n, double b) { Balance[3];
name = n; current[0] = new
bal = b; Balance("K. J. Fielding", 123.23);
} current[1] = new
void show() { Balance("Will Tell", 157.02);
if(bal<0) current[2] = new
Balance("Tom Jackson", -12.33);
System.out.print("—> "); for(int i=0; i<3; i++)

System.out.println(name + ": $" + bal); current[i].show();


} }
} }
Overview of java.lang
• Provides classes that are considered fundamental to the design of the Java
programming language.
• The java.lang package does NOT have to be imported
• Classes of java.lang
• Object
• String
• StringBuffer
• System
• The “Wrapper” Classes
• Math

You might also like