0% found this document useful (0 votes)
104 views9 pages

Understanding Java Interfaces

An interface in Java is a blueprint of a class that defines static constants and abstract methods. Interfaces are used to achieve abstraction and multiple inheritance. A class implements an interface to provide the implementation of the abstract methods defined in the interface. Interfaces cannot be instantiated and can only contain abstract methods, while abstract classes can contain both abstract and non-abstract methods.
Copyright
© All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
104 views9 pages

Understanding Java Interfaces

An interface in Java is a blueprint of a class that defines static constants and abstract methods. Interfaces are used to achieve abstraction and multiple inheritance. A class implements an interface to provide the implementation of the abstract methods defined in the interface. Interfaces cannot be instantiated and can only contain abstract methods, while abstract classes can contain both abstract and non-abstract methods.
Copyright
© All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd

Interface in Java

An interface in java is a blueprint of a class. It has static constants and abstract methods.

The interface in java is a mechanism to achieve abstraction. There can be only abstract
methods in the java interface not method body. It is used to achieve abstraction and multiple
inheritance in Java.

Java Interface also represents IS-A relationship.

It cannot be instantiated just like abstract class.

Why use Java interface?

There are mainly three reasons to use interface. They are given below.

 It is used to achieve abstraction.


 By interface, we can support the functionality of multiple inheritance.
 It can be used to achieve loose coupling.

Internal addition by compiler


The java compiler adds public and abstract keywords before the interface method. More, it adds
public, static and final keywords before data members.

In other words, Interface fields are public, static and final by default, and methods are public and
abstract.

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 A6 implements printable
{  
public void print()
{
[Link]("Hello");
}  
   public static void main(String args[])
{  
A6 obj = new A6();  
[Link]();  
  }  
}

Output:

Hello
Java Interface Example: Drawable

In this example, Drawable interface has only one method. Its implementation is provided by
Rectangle and Circle classes. In real scenario, 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: [Link]

//Interface declaration: by first user  
interface Drawable
{  
void draw();  
}  
//Implementation: by second user  
class Rectangle implements Drawable
{  
public void draw()
{
[Link]("drawing rectangle");
}  
}  
class Circle implements Drawable
{  
public void draw()
{
[Link]("drawing circle");
}  
}  
//Using interface: by third user  
class TestInterface1
{  
public static void main(String args[])
{  
Drawable d=new Circle(); 
[Link]();  
}
}  

Output:
drawing circle

Java Interface Example: Bank

Let's see another example of java interface which provides the implementation of Bank interface.
File: [Link]

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();  
[Link]("ROI: "+[Link]());  
}
}  

Output:
ROI: 9.15

Multiple inheritance in Java by interface

If a class implements multiple interfaces, or an interface extends multiple interfaces i.e. known
as multiple inheritance.
interface Printable
{  
void print();  
}  
interface Showable
{  
void show();  
}  
class A7 implements Printable,Showable
{  
public void print()
{
[Link]("Hello");
}  
public void show()
{
[Link]("Welcome");
}  
  public static void main(String args[])
{  
A7 obj = new A7();  
[Link]();  
[Link]();  
  }  
}  

Output:
Hello
Welcome
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()
{
[Link]("Hello");
}  
public static void main(String args[])
{  
TestTnterface1 obj = new TestTnterface1();  
[Link]();  
  }  
}  

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()
{
[Link]("Hello");
}  
public void show()
{
[Link]("Welcome");
}  
   public static void main(String args[])
{  
TestInterface4 obj = new TestInterface4();  
[Link]();  
[Link]();  
  }  
}  

Output:
Hello
Welcome

Java Nested Interface

An interface i.e. declared within another interface or class is known as nested interface. The
nested interfaces are used to group related interfaces so that they can be easy to maintain. The
nested interface must be referred by the outer interface or class. It can't be accessed directly.

Points to remember for nested interfaces

There are given some points that should be remembered by the java programmer.

 Nested interface must be public if it is declared inside the interface but it can have any
access modifier if declared within the class.
 Nested interfaces are declared static implicitly.

Syntax of nested interface which is declared within the interface


interface interface_name
{  
  ...  
  interface nested_interface_name
{  
   ...  
  }  
}   
Example of nested interface which is declared within the interface
In this example, we are going to learn how to declare the nested interface and how we can access
it.
interface Showable
{  
   void show();  
   interface Message
{  
    void msg();  
   }  
}  
class TestNestedInterface1 implements [Link]
{  
  public void msg()
{
[Link]("Hello nested interface");
}  
    public static void main(String args[])
{  
   [Link] message=new TestNestedInterface1();  
   [Link]();  
  }  
}  

Output:
Hello nested interface

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

1) Abstract class can have abstract and Interface can have only abstract methods. Since
non-abstract methods. Java 8, it can have default and static methods also.

2) Abstract class doesn't support


Interface supports multiple inheritance.
multiple inheritance.
3) Abstract class can have final, non-
Interface has only static and final variables.
final, static and non-static variables.

4) Abstract class can provide the Interface can't provide the implementation of
implementation of interface. abstract class.

5) The abstract keyword is used to


The interface keyword is used to declare interface.
declare abstract class.

6) Example: Example:
public abstract class Shape{ public interface Drawable{
public abstract void draw(); void draw();
} }

Simply, abstract class achieves partial abstraction (0 to 100%) whereas interface achieves fully
abstraction (100%).

Common questions

Powered by AI

A Java class can implement multiple interfaces, allowing it to inherit behavior from multiple sources without the ambiguity associated with class-based multiple inheritance. For example, a class 'A7' can implement both 'Printable' and 'Showable' interfaces, providing implementations for their respective methods . This does not constitute multiple inheritance because interfaces do not contain any method implementations, just declarations. Thus, there is no risk of conflicting implementations that typically arise with multiple inheritance in classes, as the implementations are uniquely provided by the implementing class .

A Java developer might prefer using interfaces over abstract classes when there is a need to define a contract for unrelated classes to implement, ensuring a specific behavior across different implementations. Interfaces are also the choice when it is necessary to support multiple inheritance since a class can implement multiple interfaces whereas it can only extend one class . Additionally, if all methods intended for use are abstract, and the goal is to achieve full abstraction, interfaces would be the preferable option over abstract classes .

Interfaces in Java are primarily used to achieve abstraction, support multiple inheritance, and achieve loose coupling . Interfaces consist only of abstract methods and cannot be instantiated, which provides 100% abstraction. In contrast, abstract classes can have both abstract and non-abstract methods, providing partial abstraction (0 to 100%). While abstract classes can contain final, non-final, static, and non-static variables, interfaces contain only static and final variables . Furthermore, abstract classes do not support multiple inheritance, whereas interfaces do . Finally, while an abstract class can provide the implementation of an interface, an interface cannot provide the implementation of an abstract class .

Java interfaces contribute to achieving loose coupling by defining a contract that different parts of a program can rely on without being concerned with the specific implementations. This allows for swapping or modifying implementations without affecting the larger system. For instance, a 'Drawable' interface can have different implementations, like 'Rectangle' and 'Circle', which can be used interchangeably in a program that utilizes the interface type . This decouples the interface from its implementations, allowing for easy change and scalability in design .

The IS-A relationship in Java interfaces refers to a type relationship where a class that implements an interface is essentially a type of the interface. This portrays an inheritance-like hierarchy. For example, if a class 'Circle' implements an interface 'Drawable', 'Circle' can be considered a type of 'Drawable'. This IS-A relationship is significant in polymorphism, where an interface reference can point to any of its implementing classes, such as using 'Drawable d = new Circle();' to refer to a circle object as a drawable .

Multiple inheritance in Java is achieved through interfaces rather than classes because interfaces only declare methods without providing implementations. This eliminates ambiguity, as the implementing class provides the specific method implementations . In the case where two interfaces declare methods with the same signature, like 'Printable' and 'Showable' both having 'void print();', the implementing class provides the actual implementation, thus avoiding any conflict or ambiguity . In contrast, classes contain implementation details, and attempting multiple inheritance through classes can lead to ambiguity over which method from which superclass is inherited .

The Java compiler plays a crucial role in handling the default behaviors of interfaces. For instance, when processing an interface, the compiler implicitly adds 'public' and 'abstract' keywords before all interface methods, and 'public', 'static', and 'final' keywords before all data members . This ensures that interface members are effectively equivalent to constants and uniformly accessible, reinforcing the abstraction mechanisms inherent in interface usage. This automated addition by the compiler emphasizes the role of interfaces in providing a consistent, predefined contract for implementing classes .

Interfaces in Java cannot be instantiated because they only declare method signatures and do not provide implementations. As such, they serve as a contract or a blueprint. Functionality is realized when a class implements the interface, providing concrete implementations for all its methods . This allows objects of the implementing classes to act as instances of the interface type, which can then be used to invoke the methods defined by the interface, thereby achieving polymorphism and separation of interface and implementation .

Nested interfaces in Java are used to group related interfaces for easier maintenance and code readability. Nested interfaces are those declared within another interface or class and can implicitly be static . When declared inside an interface, nested interfaces must be public, though they can have any access modifier if declared within a class . Accessibility requires that the nested interface be referenced through the outer interface or class, meaning it cannot be accessed directly . For example, if a nested interface 'Message' is declared as part of the 'Showable' interface, it must be accessed as 'Showable.Message' .

With interfaces, polymorphism is achieved by allowing multiple classes to provide different implementations for the same method defined in an interface. Consider an interface 'Drawable' with a method 'void draw();'. Both 'Rectangle' and 'Circle' implement 'Drawable', providing their distinct implementations of 'draw()' . Polymorphism is enabled by using the interface type as a reference, but invoking dynamically type-specific implementations at runtime. For instance, in 'TestInterface1', a 'Drawable' reference of type 'Circle' invokes the 'Circle' implementation of 'draw()', demonstrating runtime polymorphism .

You might also like