Download Understanding Abstract Classes and Interfaces in Java: Methods, Rules, and Differences and more Slides Java Programming in PDF only on Docsity!
Abstract class in Java
A class that is declared with abstract keyword, is known as abstract class in java. It can have abstract and non-abstract methods (method with body).
Abstraction in Java
Abstraction is a process of hiding the implementation details and showing only functionality to the user. Abstraction lets you focus on what the object does instead of how it does it.
Ways to achieve Abstaction
There are two ways to achieve abstraction in java
- Abstract class
- Interface
Abstract class in Java
A class that is declared as abstract is known as abstract class. It needs to be extended and its method implemented. It cannot be instantiated.
Example abstract class
- abstract class A{}
abstract method
A method that is declared as abstract and does not have implementation is known as abstract method.
Example abstract method
- abstract void printStatus();//no body and abstract
Example of abstract class that has abstract method
In this example, Bike the abstract class that contains only one abstract method run. It implementation is provided by the Honda class.
- 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();
- }
- } Output: running safely.. Understanding the real scenario of abstract class In this example, Shape is the abstract class, its implementation is provided by the Rectangle and Circle classes. Mostly, we don't know about the implementation class (i.e. hidden to the end user) and object of the implementation class is provided by the factory method. A factory method is the method that returns the instance of the class. In this example, if you create the instance of Rectangle class, draw() method of Rectangle class will be invoked. File: TestAbstraction1.java
- abstract class Shape{
- abstract void draw();
- }
- //In real scenario, implementation is provided by others i.e. unknown by end user
- class Rectangle extends Shape{
- void draw(){System.out.println("drawing rectangle");}
- }
- class Circle1 extends Shape{
- void draw(){System.out.println("drawing circle");}
Abstract class having constructor, data member, methods etc. An abstract class can have data member, abstract method, method body, constructor and even main() method. File: TestAbstraction2.java
- //example of abstract class that have method body
- abstract class Bike{
- Bike(){System.out.println("bike is created");}
- abstract void run();
- void changeGear(){System.out.println("gear changed");}
- }
- class Honda extends Bike{
- void run(){System.out.println("running safely..");}
- }
- class TestAbstraction2{
- public static void main(String args[]){
- Bike obj = new Honda();
- obj.run();
- obj.changeGear();
- }
- } Output bike is created running safely.. gear changed Rule: If there is any abstract method in a class, that class must be abstract.
- class Bike12{
- abstract void run();
- } Output compile time error
Rule: If you are extending any abstract class that have abstract method, you must either provide the implementation of the method or make this class abstract. Another real scenario of abstract class The abstract class can also be used to provide some implementation of the interface. In such case, the end user may not be forced to override all the methods of the interface.
Note: If you are beginner to java, learn interface first and skip this example.
- interface A{
- void a();
- void b();
- void c();
- void d();
- }
- abstract class B implements A{
- public void c(){System.out.println("I am C");}
- }
- class M extends B{
- public void a(){System.out.println("I am a");}
- public void b(){System.out.println("I am b");}
- public void d(){System.out.println("I am d");}
- }
- class Test5{
- public static void main(String args[]){
- A a= new M();
- a.a();
- a.b();
- a.c();
- a.d();
- }} Output:I am a I am b I am c I am d
Understanding relationship between classes and interfaces As shown in the figure given below, a class extends another class, an interface extends another interface but a class implements an interface.
Java Interface Example
In this example, Printable interface has only one method, its implementation is provided in the A class.
- interface printable{
- void print();
- }
- class A implements printable{
- public void print(){System.out.println("Hello");}
- public static void main(String args[]){
- A obj = new A();
- obj.print();
- }
- } Output: Hello
Java Interface Example: Drawable
In this example, Drawable interface has only one method. Its implementation is provided by Rectangle and Circle classes. Interface is defined by someone but implementation is provided by different implementation providers. And, it is used by someone else. The implementation part is hidden by the user which uses the interface. File: TestInterface1.java
- //Interface declaration: by first user
- interface Drawable{
- void draw();
- }
- //Implementation: by second user
- class Rectangle implements Drawable{
- public void draw(){System.out.println("drawing rectangle");}
- }
- class Circle implements Drawable{
- public void draw(){System.out.println("drawing circle");}
- }
- //Using interface: by third user
- class TestInterface1{
- public static void main(String args[]){
- Drawable d= new Circle();//In real scenario, object is provided by method e.g. getDrawable ()
- d.draw();
- }} Output: drawing circle
Java Interface Example: Bank
Let's see another example of java interface which provides the implementation of Bank interface. File: TestInterface2.java
- interface Bank{
- float rateOfInterest();
- }
- void show();
- }
- class A implements Printable,Showable{
- public void print(){System.out.println("Hello");}
- public void show(){System.out.println("Welcome");}
- public static void main(String args[]){
- A obj = new A();
- obj.print();
- obj.show();
- }
- } Output:Hello Welcome
Q) Multiple inheritance is not supported through class in java but it
is possible by interface, why?
As we have explained in the inheritance chapter, multiple inheritance is not supported in case of class because of ambiguity. But it is supported in case of interface because there is no ambiguity as implementation is provided by the implementation class. For example:
- interface Printable{
- void print();
- }
- interface Showable{
- void print();
- }
- class TestTnterface3 implements Printable, Showable{
- public void print(){System.out.println("Hello");}
- public static void main(String args[]){
- TestTnterface1 obj = new TestTnterface1();
- obj.print();
- }
- }
Output: Hello As you can see in the above example, Printable and Showable interface have same methods but its implementation is provided by class TestTnterface1, so there is no ambiguity. Interface inheritance A class implements interface but one interface extends another interface.
- interface Printable{
- void print();
- }
- interface Showable extends Printable{
- void show();
- }
- class TestInterface4 implements Showable{
- public void print(){System.out.println("Hello");}
- public void show(){System.out.println("Welcome");}
- public static void main(String args[]){
- TestInterface4 obj = new TestInterface4();
- obj.print();
- obj.show();
- }
- } Output: Hello Welcome Default Method in Interface Since Java 8, we can have method body in interface. But we need to make it default method. Let's see an example: File: TestInterfaceDefault.java
- interface Drawable{
Output: drawing rectangle 27
Q) What is marker or tagged interface?
An interface that have no member is known as marker or tagged interface. For example: Serializable, Cloneable, Remote etc. They are used to provide some essential information to the JVM so that JVM may perform some useful operation.
- //How Serializable interface is written?
- public interface Serializable{
- }
Nested Interface in Java
Note: An interface can have another interface i.e. known as nested interface. We will learn it in detail in the nested classes chapter. For example:
- interface printable{
- void print();
- interface MessagePrintable{
- void msg();
- }
- }
Difference between abstract class and interface
Abstract class and interface both are used to achieve abstraction where we can declare the abstract methods. Abstract class and interface both can't be instantiated. But there are many differences between abstract class and interface that are given below.
Abstract class Interface
- Abstract class can have abstract and non- abstract methods. Interface can have only abstract methods.
- Abstract class doesn't support multiple inheritance. Interface supports multiple inheritance.
- Abstract class can have final, non-final, static and non-static variables. Interface has only static and final variables.
- Abstract class can have static methods, main method and constructor. Interface can't have static methods, main method or constructor.
- Abstract class can provide the implementation of interface. Interface can't provide the implementation of abstract class.
- The abstract keyword is used to declare abstract class. The interface keyword is used to declare interface.
- Example: public abstract class Shape{ public abstract void draw(); } Example: public interface Drawable{ void draw(); }
Final Keyword In Java
The final keyword in java is used to restrict the user. The java final keyword can be used in many context. Final can be:
- variable
- method
- class The final keyword can be applied with the variables, a final variable that have no value it is called blank final variable or uninitialized final variable. It can be initialized in the constructor only. The blank final variable can be static also which will be initialized in the static block only. We will have detailed learning of these. Let's first learn the basics of final
keyword. Java final variable
If you make any variable as final, you cannot change the value of final variable(It will be constant).
Example of final variable
There is a final variable speedlimit, we are going to change the value of this variable, but It can't be changed because final variable once assigned a value can never be changed.
- class Bike9{
- final class Bike{}
- class Honda1 extends Bike{
- void run(){System.out.println("running safely with 100kmph");}
- public static void main(String args[]){
- Honda1 honda= new Honda();
- honda.run();
- }
- } Test it Now Output:Compile Time Error
Q) Is final method inherited?
Ans) Yes, final method is inherited but you cannot override it. For Example:
- class Bike{
- final void run(){System.out.println("running...");}
- }
- class Honda2 extends Bike{
- public static void main(String args[]){
- new Honda2().run();
- }
- } Test it Now Output:running...
Q) What is blank or uninitialized final variable?
A final variable that is not initialized at the time of declaration is known as blank final variable. If you want to create a variable that is initialized at the time of creating object and once initialized may not be changed, it is useful. For example PAN CARD number of an employee. It can be initialized only in constructor.
Example of blank final variable
- class Student{
- int id;
- String name;
- final String PAN_CARD_NUMBER;
- ...
- } Que) Can we initialize blank final variable? Yes, but only in constructor. For example:
- class Bike10{
- final int speedlimit;//blank final variable
- Bike10(){
5. speedlimit= 70 ;
- System.out.println(speedlimit);
- }
- public static void main(String args[]){
- new Bike10();
- }
- } Test it Now Output:
static blank final variable
A static final variable that is not initialized at the time of declaration is known as static blank final variable. It can be initialized only in static block.
Example of static blank final variable
- class A{
- static final int data;//static blank final variable
3. static { data= 50 ;}
- public static void main(String args[]){
- System.out.println(A.data);
- }