1.动手动脑
如果类提供了一个自定义的构造方法,将导致系统不再提供默认构造方法。而foo类中有一个public foo(int initValue)类,导致系统不能引用默认的构造函数。
2.动手动脑
实例:TextStaticInitialalizeBlock.java:
class Root
{
static{
System.out.println("Root的静态初始化块");
}
{
System.out.println("Root的普通初始化块");
}
public Root()
{
System.out.println("Root的无参数的构造器");
}
}
class Mid extends Root
{
static{
System.out.println("Mid的静态初始化块");
}
{
System.out.println("Mid的普通初始化块");
}
public Mid()
{
System.out.println("Mid的无参数的构造器");
}
public Mid(String msg)
{
//通过this调用同一类中重载的构造器
this();
System.out.println("Mid的带参数构造器,其参数值:" + msg);
}
}
class Leaf extends Mid
{
static{
System.out.println("Leaf的静态初始化块");
}
{
System.out.println("Leaf的普通初始化块");
}
public Leaf()
{
//通过super调用父类中有一个字符串参数的构造器
super("Java初始化顺序演示");
System.out.println("执行Leaf的构造器");
}
}
public class TestStaticInitializeBlock
{
public static void main(String[] args)
{
new Leaf();
}
}
执行结果如下:
从结果可以得出结论:
执行class Leaf extends Mid类中的静态初始化块,先要执行其父类的静态初始化块,最后才执行该类的静态初始化块。