三.程序举例
代码如下:
public class TestStaticCon {
public static int a = 0;
static {
a = 10;
System.out.println("父类的静态代码块在执行a=" + a);
}
{
a = 8;
System.out.println("父类的非静态代码块在执行a=" + a);
}
public TestStaticCon() {
this("a在父类带参构造方法中的值:" + TestStaticCon.a); // 调用另外一个构造方法
System.out.println(a);
System.out.println("父类无参构造方法在执行a=" + a);
}
public TestStaticCon(String n) {
System.out.println(n);
System.out.println(a);
}
public static void main(String[] args) {
TestStaticCon tsc = null;
System.out.println("!!!!!!!!!!!!!!!!!!!!!");
tsc = new TestStaticCon();
}
}
代码如下:
运行结果:
父类的静态代码块在执行a=10
!!!!!!!!!!!!!!!!!!!!!
父类的非静态代码块在执行a=8
a在父类带参构造方法中的值:10
8
8
父类无参构造方法在执行a=8
四.网友提供
代码如下:
public class StaticBlock {
static {
System.out.println("静态块");
}
{
System.out.println("构造块,在类中定义");
}
public StaticBlock() {
System.out.println("构造方法执行");
}
public static void main(String[] args) {
new StaticBlock();
new StaticBlock();
}
}
代码如下:
静态块
构造块,在类中定义
构造方法执行
构造块,在类中定义
构造方法执行
结论:静态代码块是在类加载时自动执行的,非静态代码块是在创建对象时自动执行的代码,不创建对象不执行该类的非静态代码块。且执行顺序为静态代码块------非静态代码块----构造函数。
其中让我疑惑的是“a在父类带参构造方法中的值:10”,我再想那时候为什么不是8,debug了(F11,不能直接设置断点然后运行,那样和直接运行没区别),发现先进入了无参的构造方法,执行了第一条语句并且切换到了另一个构造方法(不管是不是反正第一句都要执行,此时a还是10,非静态代码块还未执行),提示找不到源,不管是不是这条语句都提示了这个警告(不算错误,因为程序继续正常运行),然后运行了非静态代码块,继而从有参的构造方法处继续执行……