java中接口是否继承Object类

Java中,接口是否继承自Object?

空口无凭,上代码:

public interface InterfaceFather {

}

一个空接口,反编译一下:

所以,老师说,接口是继承Object滴

可我还是感觉上面那位兄弟说的没毛病,,

那我只能自己动手,丰衣足食了,还是上面那个空接口,再新建一个空类:

public class ClassFather {
  
}

然后通过反射获取他俩及其父类的方法:

public class InterfaceFatherTest {
    public static void main(String[] args) {
        Class<InterfaceFather> interfaceClazz = InterfaceFather.class;
        Method[] interfaceMethods = interfaceClazz.getMethods();
        // 获取到的方法个数为0
        System.out.println(interfaceMethods.length);

        InterfaceFather interfaceFather = null;
        // 能访问Object里的方法(虽然不能运行)
        interfaceFather.hashCode();

        Class<ClassFather> classClazz = ClassFather.class;
        Method[] classMethods = classClazz.getMethods();
        // 可以获取到Object里的方法
        System.out.println(classMethods.length);
    }
}

执行结果见注释~

神奇不?

总结一下目前的现象:

    反编译看到接口继承自Object
    反射获取不到接口继承自Object的方法,但接口对象可以访问Object的方法

特别是第二条,完全就是矛盾的

这时候,我已经觉着老师说的对了,接口肯定继承自Object,不然不能访问Object的方法

但为啥反射获取不到嘞?

我猜测问题应该出在反射上

看下getMethods()源码

@CallerSensitive
public Method[] getMethods() throws SecurityException {
     checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), true);
     return copyMethods(privateGetPublicMethods());
}

不得不说,人家这名字起的就是好,没猜错的话应该是进入privateGetPublicMethods()方法:

private Method[] privateGetPublicMethods() {
        checkInitted();
        Method[] res;
        ReflectionData<T> rd = reflectionData();
        if (rd != null) {
            res = rd.publicMethods;
            if (res != null) return res;
        }

        // No cached value available; compute value recursively.
        // Start by fetching public declared methods
        MethodArray methods = new MethodArray();
        {
            Method[] tmp = privateGetDeclaredMethods(true);
            methods.addAll(tmp);
        }
        // Now recur over superclass and direct superinterfaces.
        // Go over superinterfaces first so we can more easily filter
        // out concrete implementations inherited from superclasses at
        // the end.
        MethodArray inheritedMethods = new MethodArray();
        for (Class<?> i : getInterfaces()) {
            inheritedMethods.addInterfaceMethods(i.privateGetPublicMethods());
        }
        if (!isInterface()) {
            Class<?> c = getSuperclass();
            if (c != null) {
                MethodArray supers = new MethodArray();
                supers.addAll(c.privateGetPublicMethods());
                // Filter out concrete implementations of any
                // interface methods
                for (int i = 0; i < supers.length(); i++) {
                    Method m = supers.get(i);
                    if (m != null &&
                            !Modifier.isAbstract(m.getModifiers()) &&
                            !m.isDefault()) {
                        inheritedMethods.removeByNameAndDescriptor(m);
                    }
                }
                // Insert superclass's inherited methods before
                // superinterfaces' to satisfy getMethod's search
                // order
                supers.addAll(inheritedMethods);
                inheritedMethods = supers;
            }
        }
        // Filter out all local methods from inherited ones
        for (int i = 0; i < methods.length(); i++) {
            Method m = methods.get(i);
            inheritedMethods.removeByNameAndDescriptor(m);
        }
        methods.addAllIfNotPresent(inheritedMethods);
        methods.removeLessSpecifics();
        methods.compactAndTrim();
        res = methods.getArray();
        if (rd != null) {
            rd.publicMethods = res;
        }
        return res;
    }

就是他:

...
if (!isInterface()) {
            Class<?> c = getSuperclass();
...

只有是类的时候,才会去获取它的父类信息

所以,我们使用反射获取不到接口中Object的方法

 

转自:https://blog.csdn.net/weixin_43955020/article/details/123859048

posted on 2023-09-20 22:45  HHHuskie  阅读(67)  评论(0编辑  收藏  举报

导航