为了澄清静态的误解,我将简单地提到这段代码:public class Foo {
{ System.out.println("Instance Block 1"); }
static { System.out.println("Static Block 1"); }
public static final Foo FOO = new Foo();
{ System.out.println("Instance Block 2"); }
static { System.out.println("Static Block 2 (Weird!!)"); }
public Foo() { System.out.println("Constructor"); }
static public void main(String p[]) {
System.out.println("In Main");
new Foo();
}}
令人惊讶的是,产出如下:Static Block 1
Instance Block 1
Instance Block 2
Constructor
Static Block 2 (Weird!!)
In Main
Instance Block 1
Instance Block 2
Constructor
请注意,我们有一个static {}这就是所谓的后两个实例{}..这是因为我们将构造函数放在中间,在第一次调用构造函数时插入执行顺序。
基本上,我们观察到这种情况会发生:在第一次初始化对象时,根据发生顺序将静态初始化和实例初始化混合在一起初始化当前对象。
对于所有下一个初始化,只按发生顺序进行实例初始化,因为静态初始化已经发生。
我需要研究继承的组合,以及对超级的显式和隐式调用,这将影响这一点,并将更新结果。它可能类似于其他提供的答案,只是他们在静态初始化中出错了。