Skip to main content

Difference between Abstract class and Interface in Java Interview

Abstraction can be achieved in Java using abstract classes and interfaces.

Abstract classes

  • An abstract class is a class that cannot be instantiated directly. It must be subclassed and the subclass must implement all of the abstract methods of the abstract class.
  • An abstract class can have both abstract and non-abstract methods.
  • An abstract class can have variables and constants.
  • An abstract class can have constructors.

Example:

java
public abstract class Animal { public abstract void makeSound(); }

Interfaces

  • An interface is a reference type that defines a set of methods that must be implemented by classes that implement the interface.
  • An interface cannot have any abstract methods. All of the methods in an interface are abstract by default.
  • An interface cannot have any variables or constants.
  • An interface cannot have constructors.

Example:

java
public interface Flyable { void fly(); }

Real-time use-cases in Java

  • Abstract class: Abstract classes are often used to implement inheritance. For example, the java.lang.Object abstract class is used to implement inheritance for all other classes in Java.
  • Interface: Interfaces are often used to implement polymorphism. For example, the java.io.Serializable interface is used to implement polymorphism for classes that can be serialized and deserialized.
Here is an example of a class that inherits from the Animal abstract class and implements the Flyable interface:

Example:

java
public class Bird extends Animal implements Flyable { public void makeSound() { System.out.println("Chirp!"); } public void fly() { System.out.println("Flap flap!"); } }

This class implements both the makeSound() method and the fly() method. It can therefore be used to create objects that can both make a sound and fly.

Abstract classes and interfaces are two powerful tools that can be used to improve the design of your Java code. By using abstract classes and interfaces, you can make your code more reusable, flexible, and maintainable.



Comments

Popular posts from this blog

Using Java 8 Streams to Find the Second-Highest Salary in an Employee List

To find the second-highest salary from a list of employees using Java 8 streams, you can follow these steps: Create a list of employees with their salaries. Use Java 8 streams to sort the employees by salary in descending order. Skip the first element (which is the employee with the highest salary). Get the first element of the remaining stream (which is the employee with the second-highest salary). Example code: java import java.util.ArrayList; import java.util.List; class Employee { private String name; private double salary; public Employee (String name, double salary) { this .name = name; this .salary = salary; } public double getSalary () { return salary; } } public class SecondHighestSalary { public static void main (String[] args) { List<Employee> employees = new ArrayList <>(); employees.add( new Employee ( "John" , 60000.0 )); employees.add( new Employe...

Java Data Structures and Algorithms: A Practical Guide with Examples and Top Interview Questions"

Data Structures and Algorithms in Java Understanding Data Structures ArrayList When to Use: Use ArrayList when you need a dynamic array that can grow or shrink in size. It's efficient for random access but less efficient for frequent insertions and deletions. Example Code: java List<String> arrayList = new ArrayList <>(); arrayList.add( "Java" ); arrayList.add( "Data Structures" ); arrayList.add( "Algorithms" ); LinkedList When to Use: LinkedList is suitable for frequent insertions and deletions. It provides better performance than ArrayList in scenarios where elements are frequently added or removed from the middle of the list. Example Code: java LinkedList<String> linkedList = new LinkedList <>(); linkedList.add( "Java" ); linkedList.add( "Data Structures" ); linkedList.add( "Algorithms" ); HashMap When to Use: Use HashMap for fast retrieval of data based on a key. It is efficient for loo...

Mastering Java Streams: A Complete Guide with Examples and Interview Questions

Java Streams have revolutionized the way data processing tasks are handled in Java programming. Introduced in Java 8, Streams offer a fluent and functional approach to processing collections of objects. In this guide, we'll delve into what Streams are, how they work, and provide practical examples along the way. Understanding Java Streams: Java Streams represent a sequence of elements that can be processed sequentially or in parallel. They provide a pipeline through which data can be manipulated using various operations such as filtering, mapping, sorting, and aggregating. Benefits of Java Streams: Concise and Readable Code : Streams promote a functional programming style, leading to more concise and readable code compared to traditional imperative approaches. Lazy Evaluation : Stream operations are lazily evaluated, meaning elements are processed only when necessary, improving efficiency. Parallelism : Streams can leverage parallel processing for improved performance on multicore ...

Subscribe to get new posts

Name

Email *

Message *