首页 > 代码库 > 动手动脑,无法自拔(2)

动手动脑,无法自拔(2)

1.动手动脑

 技术分享

如果类提供了一个自定义的构造方法,将导致系统不再提供默认构造方法。而foo类中有一个public fooint 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类中的静态初始化块,先要执行其父类的静态初始化块,最后才执行该类的静态初始化块。

动手动脑,无法自拔(2)