Do interfaces inherit from Object class in java

31,875

Solution 1

Do interfaces inherit from Object class in Java?

No, they don't. And there is no common "root" interface implicitly inherited by all interfaces either (as in the case with classes) for that matter.(*)

If no then how we are able to call the method of object class on interface instance

An interface implicitly declared one method for each public method in Object. Thus the equals method is implicitly declared as a member in an interface (unless it already inherits it from a superinterface).

This is explained in detail in the Java Language Specification, § 9.2 Interface Members.

9.2 Interface Members

[...]

  • If an interface has no direct superinterfaces, then the interface implicitly declares a public abstract member method m with signature s, return type r, and throws clause t corresponding to each public instance method m with signature s, return type r, and throws clause t declared in Object, unless a method with the same signature, same return type, and a compatible throws clause is explicitly declared by the interface.

[...]


This post has been rewritten as an article here.


(*) Note that the notion of being a subtype of is not equivalent to inherits from: Interfaces with no super interface are indeed subtypes of Object (§ 4.10.2. Subtyping among Class and Interface Types ) even though they do not inherit from Object.

Solution 2

Object is a supertype of any interface [1]

However, an interface does not implements, extends, or, "inherit from" Object.

JLS has a special clause to add Object methods into interfaces [2]

[1] http://java.sun.com/docs/books/jls/third_edition/html/typesValues.html#4.10.2

[2] http://java.sun.com/docs/books/jls/third_edition/html/interfaces.html#9.2

Solution 3

There is actually a superclass field in every .class file, including those that represent interfaces.

For an interface it always points to java.lang.Object. But that isn't used for anything.

Another way to look at it is:

interface MyInterface {
    // ...
}

public myMethod(MyInterface param) {
    Object obj = (Object) param;
    // ...
}

Here the cast (Object) param is always valid, which implies that every interface type is a subtype of java.lang.Object.

Solution 4

That's because employee e = ... reads that there is a class that implements employee, and is assigned to variable e. Every class that implements an interface extends Object implicitly, hence when you do e.equals(null), the language knows that you have a class that is a subtype of employee.

The JVM will do runtime checking for your code (i.e. throw NullPointerException).

Solution 5

Is interface inherits Object class, how can we able to access the methods of object class through a interface type reference
No Interface does not inherits Object class, but it provide accessibility to all methods of Object class. The members of an interface are:

Those members declared in the interface.
Those members inherited from direct superinterfaces.
If an interface has no direct superinterfaces, then the interface implicitly 

declares a public abstract member method corresponding to each public instance method declared in Object class.
It is a compile-time error if the interface explicitly declares such a method m in the case where m is declared to be final in Object.

Now it is clear that all superinterface have abstract member method corresponding to each public instance method declared in Object.

source: http://ohmjavaclasses.blogspot.com/2011/11/is-intreface-inherits-object-clashow.html

Share:
31,875

Related videos on Youtube

ponds
Author by

ponds

Java Developer

Updated on May 30, 2021

Comments

  • ponds
    ponds about 3 years

    Do interfaces inherit from Object class in Java?

    If no then how we are able to call the method of object class on interface instance

    public class Test {
        public static void main(String[] args) {
            Employee e = null;
            e.equals(null);
        }
    }
    
    interface Employee {
    }
    
    • aioobe
      aioobe about 12 years
      @EJP, technically speaking it doesn't matter what java/io/Serializable.class contains. I think you're confusing the Java Lang Spec with the JVM spec.
    • user207421
      user207421 about 12 years
      @aioobe As I haven't mentioned either of those specifications I don't understand your point. Serializable is an interface, the simplest possible; running javap on it tells you what it inherits from; and that is dictated by the Java Language Specification. If you think the JVM Spec comes into it somewhere please enlighten us.
    • aioobe
      aioobe over 11 years
      @EJP, the question is about the Java language (i.e. the Java Language Specification). What ever java/io/Serializable.class contains is related to what the JVM spec says. Technically speaking there is no guarantee that there is a one-to-one correspondence between features of the two specifications.
    • aioobe
      aioobe almost 8 years
      I elaborated on this in a recent blog post.
  • corsiKa
    corsiKa almost 11 years
    Does this explain the behavior of boolean isObject = myList instanceof Object being true? Or is that because instanceof looks at what the object actually is, not what your reference to it is.
  • aioobe
    aioobe almost 11 years
    instanceof performs the check against the runtime type (otherwise the whole instanceof-expression could be evaluated at compile time).
  • Vikas Mangal
    Vikas Mangal almost 10 years
    @aioobe If we implement any interface, then why don't we give the implementation of "equals" method in the class which is implementing that interface. According to my concepts,we have to implement the methods of interface in implementing class otherwise the class will be abstract.
  • aioobe
    aioobe almost 10 years
    You don't need to (re)implement inherited methods. Have a look at this example. In other words, equals is already defined and inherited to the class implementing the interface.
  • overexchange
    overexchange over 9 years
    After reading this answer, it makes more sense to see class Object as class Root in java.
  • aioobe
    aioobe over 9 years
    The .class file is an artifact of the .java file. To argue why something works in Java language by looking at the resulting .class file is backward reasoning.
  • Vikas Mangal
    Vikas Mangal over 9 years
    I got the point here. But one question- why do we need this? What difference it would have made if the methods of Object class would not have been declared in the interface ?
  • aioobe
    aioobe over 9 years
    If we didn't have this, the program in the question would not compile. There is on equals method in the Employee interface.
  • Dhanaraj Durairaj
    Dhanaraj Durairaj almost 9 years
    below Oracle link states that, "Reference types all inherit from java.lang.Object. Classes, enums, arrays, and interfaces are all reference types." This is contradicting. Can someone throw light on it ? Lesson: Classes @aioobe
  • Anand Kadhi
    Anand Kadhi over 8 years
    This question and answer still reminds me that even after experience i should focus on making my basics strong.
  • prvn
    prvn almost 8 years
    What happens in the following case : Class Dummy extends Test implements Employee {...} . Dummy would have two methods with same signature (one defined in Object class and the other declared in interface Employee) ?
  • aioobe
    aioobe almost 8 years
    @prvn, that's not a problem since there's still just one implementation of the method.
  • Number945
    Number945 about 6 years
    Classes, enums, and arrays (which all inherit from java.lang.Object) as well as interfaces are all reference types : it does not say interface inherits from Object. Only Classes , enums and arrays.
  • dalvarezmartinez1
    dalvarezmartinez1 about 6 years
    They changed it :)
  • nme
    nme over 5 years
    That's the most accurate answer. Should be the accepted one. E.g. a method which takes a java.lang.Object will also accept a reference of any interface type. Moreover you can cast interface to an Object implicitly without any compiler error.
  • sabarinathan u
    sabarinathan u about 5 years
    Object obj = (Object) param; does not throw compilation error. But MyInterface's methods (public) are not visible to obj. Therefore can't assume MyInterface is every interface type is a subtype of java.lang.Object
  • Lew Bloch
    Lew Bloch over 4 years
    Even if "they changed it" (which I doubt), the tutorial can be wrong. The normative reference is the Java Language Specification (JLS).
  • jaco0646
    jaco0646 almost 4 years
    Why do interfaces need this special treatment? Wouldn't it have been simpler to inherit from Object like everything else?