- 构造函数实际上是静态方法;
- 调用构造函数会先引发静态初始化,再引发普通初始化。因为构造函数是静态方法(调用会引发静态初始化),又会创建对象(引发普通初始化)。
class Cup{ Cup(int marker){ System.out.println("Cup("+marker+")"); } void f1(int marker){ System.out.println("f1("+marker+")"); } } class Cups{ static Cup cup1 = new Cup(1); Cup cup2 = new Cup(2); { Cup cup3 = new Cup(3); } static{ Cup cup4 = new Cup(4); } Cups(){ System.out.println("Cups()"); } static void f2(int marker){ System.out.println("f2("+marker+")"); } } public class ExplicitStatic { public static void main(String[] args) { System.out.println("Inside main()"); Cups.f2(5); // Cups cups = new Cups(); } }
输出结果为:
Inside main() Cup(1) Cup(4) f2(5) Process finished with exit code 0
此结果验证了1-2中的规律5:调用除构造函数外静态方法只会引发静态初始化,而不会引发普通初始化。因为类中的普通成员变量cup2、cup3并未被显示初始化。
public class ExplicitStatic { public static void main(String[] args) { System.out.println("Inside main()"); // Cups.f2(5); Cups cups = new Cups(); } }
输出的结果为:
Inside main() Cup(1) Cup(4) Cup(2) Cup(3) Cups() Process finished with exit code 0
此结果验证了1-2中的规律6 以及 初始化顺序的优先级。