Tutorial

Difference between Abstract Class and Interface in Java

Published on August 4, 2022
author

Pankaj

Difference between Abstract Class and Interface in Java

Difference between Abstract Class and Interface is one of the popular interview questions. Abstract Class and Interface are a core part of the Java programming language. Whether to choose an interface or abstract class is a design decision that every architect faces. In my last articles, I have provided as much as possible details about java interface and abstract class. In this post, we will learn about the difference between abstract class and Interface and when should we use interface over the abstract class and vice versa.

Difference between Abstract Class and Interface

  1. abstract keyword is used to create an abstract class and it can be used with methods also whereas interface keyword is used to create interface and it can’t be used with methods.
  2. Subclasses use extends keyword to extend an abstract class and they need to provide implementation of all the declared methods in the abstract class unless the subclass is also an abstract class whereas subclasses use implements keyword to implement interfaces and should provide implementation for all the methods declared in the interface.
  3. Abstract classes can have methods with implementation whereas interface provides absolute abstraction and can’t have any method implementations. Note that from Java 8 onwards, we can create default and static methods in interface that contains the method implementations.
  4. Abstract classes can have constructors but interfaces can’t have constructors.
  5. Abstract class have all the features of a normal java class except that we can’t instantiate it. We can use abstract keyword to make a class abstract but interfaces are a completely different type and can have only public static final constants and method declarations.
  6. Abstract classes methods can have access modifiers as public, private, protected, static but interface methods are implicitly public and abstract, we can’t use any other access modifiers with interface methods.
  7. A subclass can extend only one abstract class but it can implement multiple interfaces.
  8. Abstract classes can extend other class and implement interfaces but interface can only extend other interfaces.
  9. We can run an abstract class if it has main() method but we can’t run an interface because they can’t have main method implementation.
  10. Interfaces are used to define contract for the subclasses whereas abstract class also define contract but it can provide other methods implementations for subclasses to use.

That’s all for the difference between an interface and abstract classes, now we can move on to know when should we use Interface over Abstract class and vice versa.

Interface or Abstract Class

Whether to choose between Interface or abstract class for providing a contract for subclasses is a design decision and depends on many factors. Let’s see when Interfaces are the best choice and when can we use abstract classes.

  1. Java doesn’t support multiple class level inheritance, so every class can extend only one superclass. But a class can implement multiple interfaces. So most of the times Interfaces are a good choice for providing the base for class hierarchy and contract. Also coding in terms of interfaces is one of the best practices for coding in java.
  2. If there are a lot of methods in the contract, then abstract class is more useful because we can provide a default implementation for some of the methods that are common for all the subclasses. Also if subclasses don’t need to implement a particular method, they can avoid providing the implementation but in case of interface, the subclass will have to provide the implementation for all the methods even though it’s of no use and implementation is just empty block.
  3. If our base contract keeps on changing then interfaces can cause issues because we can’t declare additional methods to the interface without changing all the implementation classes, with the abstract class we can provide the default implementation and only change the implementation classes that are actually going to use the new methods.

Use Abstract classes and Interface both

Using interfaces and abstract classes together is the best approach to design a system. For example, in JDK java.util.List is an interface that contains a lot of methods, so there is an abstract class java.util.AbstractList that provides a skeletal implementation for all the methods of List interface so that any subclass can extend this class and implement only required methods. We should always start with an interface as the base and define methods that every subclass should implement and then if there are some methods that only certain subclass should implement, we can extend the base interface and create a new interface with those methods. The subclasses will have the option to chose between the base interface or the child interface to implement according to its requirements. If the number of methods grows a lot, it’s not a bad idea to provide a skeletal abstract class implementing the child interface and providing flexibility to the subclasses to chose between interface and an abstract class.

Java 8 interface changes

From Java 8 onwards, we can have method implementations in the interfaces. We can create default as well as static methods in the interfaces and provide an implementation for them. This has bridged the gap between abstract classes and interfaces and now interfaces are the way to go because we can extend it further by providing default implementations for new methods. For more details, check out Java 8 interface default static methods.

Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.

Learn more about our products

About the author(s)

Category:
Tutorial
Tags:

While we believe that this content benefits our community, we have not yet thoroughly reviewed it. If you have any suggestions for improvements, please let us know by clicking the “report an issue“ button at the bottom of the tutorial.

Still looking for an answer?

Ask a questionSearch for more help

Was this helpful?
 
JournalDev
DigitalOcean Employee
DigitalOcean Employee badge
July 16, 2013

Hello Pankaj, I like this post much. I got clear idea about when to use interfaces and when to use abstract class. But i didnt understand last paragraph i.e extending interface. could u elobarate more. So that it will understandable. I will be clear if u provide some bit of code. Please Thanks.

- sunil patil

JournalDev
DigitalOcean Employee
DigitalOcean Employee badge
July 16, 2013

It feels great that you liked the post, as I mentioned that once you have created an interface, its hard to change its behaviors because that would result in compilation error for all the implementation classes, so we can use interfaces extend functionality to create a new interface rather than changing the base interface. To learn more about this, read https://www.journaldev.com/1601/what-is-interface-in-java-example-tutorial

- Pankaj

    JournalDev
    DigitalOcean Employee
    DigitalOcean Employee badge
    August 15, 2013

    Hi Pankaj Sir, Thank You for sharing this wonderful site with us. Would be Thankful to you,if you can shed light on ANT,JUnit,TestNG topics too. I am an Automation tester in Selenium and am looking forward for the topics mentioned above,since,your experience and understanding helps us understand the topics better. Thanks Again. ~Chaitanya

    - Madiraju Krishna Chaitanya

    JournalDev
    DigitalOcean Employee
    DigitalOcean Employee badge
    August 15, 2013

    ANT is an outdated technology now when it comes to build and deployment tools, I am planning to post some tutorials for Maven. JUnit and TestNG tutorials will also arrive in coming months. Thanks for your kind words, it pushes me to keep going.

    - Pankaj

    JournalDev
    DigitalOcean Employee
    DigitalOcean Employee badge
    September 23, 2013

    You have given 8.Abstract classes can extend other class and implement interfaces but interface can only extend other interfaces. I have a doubt can abstract class “extend” another abstract class or “implement” another abstract class reply to my email please…

    - Lucas

      JournalDev
      DigitalOcean Employee
      DigitalOcean Employee badge
      September 17, 2013

      you mentioned in last point"Interfaces are used to define contract for the subclasses" like what is ’ contract here’ klindly explain that point

      - lakshmi

      JournalDev
      DigitalOcean Employee
      DigitalOcean Employee badge
      September 17, 2013

      Contract are the behavior methods that are declared in the interface that all the implementation classes must define.

      - Pankaj

      JournalDev
      DigitalOcean Employee
      DigitalOcean Employee badge
      October 9, 2013

      very good collective information on abstract and interfcae

      - Tuntun kumar

        JournalDev
        DigitalOcean Employee
        DigitalOcean Employee badge
        September 18, 2013

        sir can u give me reply for the question i have asked on last point

        - lakshmi

          JournalDev
          DigitalOcean Employee
          DigitalOcean Employee badge
          September 18, 2013

          thank u sir

          - lakshmi

            JournalDev
            DigitalOcean Employee
            DigitalOcean Employee badge
            November 29, 2013

            sir 8. interface can only extend other interfaces. but interface only implements other interface correct

            - sha

            JournalDev
            DigitalOcean Employee
            DigitalOcean Employee badge
            November 29, 2013

            Abstract class can implement interfaces because it’s like normal class with some abstract methods. Interfaces don’t have implementation, so they can ONLY extend other interfaces.

            - Pankaj

              JournalDev
              DigitalOcean Employee
              DigitalOcean Employee badge
              December 21, 2013

              the best explanation i came across. going to copy this page forever.

              - rishi

                JournalDev
                DigitalOcean Employee
                DigitalOcean Employee badge
                December 28, 2013

                best explanation,Thank you.

                - prabhu

                  JournalDev
                  DigitalOcean Employee
                  DigitalOcean Employee badge
                  March 19, 2014

                  thank You …for giving very good explanation…

                  - Swati Aher

                    JournalDev
                    DigitalOcean Employee
                    DigitalOcean Employee badge
                    April 9, 2014

                    very good collective information on abstract and interfcae

                    - suresh

                      JournalDev
                      DigitalOcean Employee
                      DigitalOcean Employee badge
                      January 27, 2015

                      "… Also if subclasses don’t need to implement particular method, they can avoid providing the implementation… " - does that mean we can choose NOT to implement any method of the abstract class?

                      - abhishek chanda

                        JournalDev
                        DigitalOcean Employee
                        DigitalOcean Employee badge
                        February 20, 2015

                        What is the simple definition of abstract?? Give me an example…

                        - Waseem Ahmed Kalhoro

                          JournalDev
                          DigitalOcean Employee
                          DigitalOcean Employee badge
                          June 5, 2016

                          Hi. I have a question. Assume that there is an abstract class with method String Name() and an Interface with the same method String Name(). The signatures of both methods in abstract class and interface is same. Now Class A extends the abstract class and implements the interface. Which String Name() method is implemented in Class A??? Example : //AbstractClass public abstract AbstractClass { public abstract String Name(); } //Interface Public interface SampleInterface{ public String Name(); } // which method is implemented here??? public class A extends AbstractClass implements SampleInterface{ public String Name(){ //Implementation // Which method is implemented here. The abstract class method or interface method??? } I tried executing a small sample program. The program runs fine but i am not sure as to which method is implemented here.

                          - Shwetha

                            JournalDev
                            DigitalOcean Employee
                            DigitalOcean Employee badge
                            November 8, 2016

                            You have written “The subclasses will have option to chose between the base interface or the child interface to implement according to its requirements” Hows this possible ?

                            - Aliasger Motiwala

                              JournalDev
                              DigitalOcean Employee
                              DigitalOcean Employee badge
                              April 15, 2017

                              Hi Pankaj, Good Explanation on Abstract and Interfaces. Can you Post Tutorials on MAVEN, LOG4J and JUnit. Thanks

                              - KALADHAR KHAMITHKAR

                                JournalDev
                                DigitalOcean Employee
                                DigitalOcean Employee badge
                                May 25, 2017

                                You mention that abstract class can be run throw main method while interface can’t However abstract class cant be instantiated so how JVM is going to run the abstract class. You can call any static method with Abstract class implementation, No matter it is main method or not.

                                - Oshin Talreja

                                  JournalDev
                                  DigitalOcean Employee
                                  DigitalOcean Employee badge
                                  May 30, 2017

                                  Can abstract methods in an abstract class be private? No right?

                                  - Vikas Palakurthi

                                    JournalDev
                                    DigitalOcean Employee
                                    DigitalOcean Employee badge
                                    June 22, 2017

                                    Hi Pankaj, I think “Subclasses use extends keyword to extend an abstract class and they need to provide implementation of all the declared methods in the abstract class” is not correct. It should be "Subclasses use extends keyword to extend an abstract class and they need to provide implementation of all the declared abstract methods in the abstract class "

                                    - Stan

                                      JournalDev
                                      DigitalOcean Employee
                                      DigitalOcean Employee badge
                                      July 6, 2017

                                      Great Explanation, Your article provides quality content on difference between Abstract class and Interface. It is a very common question usually asked in interviews. I agree with your all points. We can achieve Abstraction 0-100% through abstract class and 100% abstraction from Interfaces because Interface can contain only abstract methods but Abstract class may have abstract method as well as methods with implementation. I am also running a blog (java2blog) which is tutorial on Java. It also provides useful interview questions and answers on Java.

                                      - Arpit Mandliya

                                        JournalDev
                                        DigitalOcean Employee
                                        DigitalOcean Employee badge
                                        August 21, 2017

                                        Thanks for sharing this post. keep it up.

                                        - Anurag Singh

                                          Try DigitalOcean for free

                                          Click below to sign up and get $200 of credit to try our products over 60 days!

                                          Sign up

                                          Join the Tech Talk
                                          Success! Thank you! Please check your email for further details.

                                          Please complete your information!

                                          Become a contributor for community

                                          Get paid to write technical tutorials and select a tech-focused charity to receive a matching donation.

                                          DigitalOcean Documentation

                                          Full documentation for every DigitalOcean product.

                                          Resources for startups and SMBs

                                          The Wave has everything you need to know about building a business, from raising funding to marketing your product.

                                          Get our newsletter

                                          Stay up to date by signing up for DigitalOcean’s Infrastructure as a Newsletter.

                                          New accounts only. By submitting your email you agree to our Privacy Policy

                                          The developer cloud

                                          Scale up as you grow — whether you're running one virtual machine or ten thousand.

                                          Get started for free

                                          Sign up and get $200 in credit for your first 60 days with DigitalOcean.*

                                          *This promotional offer applies to new accounts only.