隐藏的Super关键字

在使用构造方法来完成对象的初始化的时候,子类对象的实例会默认的调用父类的构造方法.即使我们的super关键字是没有写的,同样会调用.来看看下面的代码.

package ooJect;

/**
 * @author hackbase  Super的使用以及测试.
 */
public class TestSuper {
    public static void main(String[] args) {
        System.out.println("开始创建一个子类的对象....");
        new ChildClass();

    }

    static class FatherClass {
        public FatherClass() {
            System.out.println("父亲有话要说!!!!");
        }
    }

    static class ChildClass extends FatherClass {
        /**
         * 子类重写了父类的方法.
         */
        public ChildClass() {
            System.out.println("孩子正在听父亲说什么了????");
        }
    }
}

在上面的代码里面,创建了2个类,分别是子类和父类,子类继承了父类。同时子类和父类分别定义了各自的构造方法。

当我们创建子类的一个实例的时候,默认会调用父类的构造方法,即使我们不屑super关键字,同样可以实现调用。

父类继承来自Object对象。因此默认调用调用Object的构造方法,这样就形成了一个继承的树状的机构。n啊么在创在对象的过程之中,首先会创建Objectt类的对象,然后在创建父类的对象,然后在创建子类的对象。同理,我们的静态初始化块也是一样,先执行父类静态初始化块,在执行子类的静态初始化块。大家可以验证一下。

猜你喜欢

转载自blog.csdn.net/hackerbaseing/article/details/89763723
今日推荐