类初始化顺序--如果类中包含自身静态属性

举个基本的例子来说明类初始化的顺序:

public class MyMain {
    public static void main(String args[]) {
        Father f = new Son();
    }
}

class Father {
    static int a = 1;
    //static Father father = new Father();
    
    static {
        System.out.println("print in father");
    }
    
    public Father() {
        System.out.println("Father Construct");
    }
}

class Son extends Father {
    static int b=1;
    //static Son son = new Son();
    
    static {
        System.out.println("print in son");
    }
    
    public Son() {
        System.out.println("Son Construct");
    }
}
上面例子的执行结果为:

print in father
print in son
Father Construct
Son Construct

从结果看到执行顺序为:父类静态属性--父类静态代码块--子类静态属性--子类静态代码块--父类构造函数--子类构造函数

但是如果把注释打开,也就是类中包含自身的属性,且为静态的,这样执行结果为:

Father Construct
print in father
Father Construct
Son Construct
print in son
Father Construct
Son Construct
从结果中可以看到执行顺序为:父类静态属性--父类构造函数--父类静态代码块--子类静态属性--子类构造函数--子类静态代码块--父类构造函数--子类构造函数


分析:从上的例子可以看出,如果类中有自身对象且为静态的,限制性构造函数,并不是一味的先执行静态的属性,构成递归。

            如果去属性的static,那么这样就构成递归了,可以用上面的里试一下就看到结果了。


你可能感兴趣的:(类初始化,自身静态属性)