Answer:
动手动脑:
1——以下代码为何无法通过编译?哪儿出错了?
Answer:
因为类Foo的构造函数是有一个参数的,所以我们在new一个Foo类的对象时必须赋予一个符合条件的实参。
2——
请运行TestStaticInitializeBlock.java示例,观察输出结果,总结出“静态初始化块的执行顺序”。
TestStaticInitializeBlock.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();} }
输出结果:
总结静态初始化块的执行顺序:
1.静态初始化块只执行一次。
2.创建子类型的对象时,也会导致父类型的静态初始化块的执行。
2.并且从父类到子类依次执行完静态初始化块。然后从父类到子类依次执行完普通初始化块。最后再从父类到子类依次执行构造函数。(执行顺序:静态初始化块——>普通初始化块——>构造函数)
要求发表的:
1——自行总结java字段初始化的规律:
Answer:
所有类的变量都默认初始化为null,比如String a; Integer b;
数字类的原始数据类型默认初始化为0,比如int a; short b; char c;
boolean默认初始化为false.
针对java中的构造函数的初始化:
对象创建的时候先赋初始化值然后在调用构造函数初始化。
类字段的初始化顺序——
1.执行类成员定义时指定的默认值或类的初始化块,到底执行哪一个要看哪一个“排在前面”。
2.执行类的构造函数:
类的初始化块不接收任何的参数,而且只要一创建类的对象,它们就会被执行。因此,适合于封装那些“对象创建时必须执行的代码”。