今天的收获是调通了一个错误程序,虽然学习的过程困难重重,但是程序调通时的喜悦也溢于言表。分享一个代码,这个程序创建了3个类,涉及到继承,初始化块,this调用和重载的问题。
package lizi;
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();
System.out.println(“Mid的带参数构造器,其参数值:”+msg);
}
}
class Leaf extends Mid
{
static
{
System.out.println(“Leaf的静态初始化块”);
}
{
System.out.println(“Leaf的普通初始化块 “);
}
public Leaf()
{
super(“疯狂讲义”);
System.out.println(“执行Leaf的构造器”);
}
}
public class Test
{
public static void main(String[] args)
{
new Leaf();
new Leaf();
}
}
运行结果如下:
Root的 静态初始化块
Mid的静态初始化块
Leaf的静态初始化块
Root的普通初始化块
Root的无参数的构造器
Mid的普通初始化块
Mid的无参数的构造器
Mid的带参数构造器,其参数值:疯狂讲义
Leaf的普通初始化块
执行Leaf的构造器
Root的普通初始化块
Root的无参数的构造器
Mid的普通初始化块
Mid的无参数的构造器
Mid的带参数构造器,其参数值:疯狂讲义
Leaf的普通初始化块
执行Leaf的构造器
小白感悟:
涉及到多个父类以及初始化块时,有一个固定的顺序。
首先是最顶层父类的静态初始化块,然后依次向下(各级父类的静态初始化块),直到执行到当前类。
其次执行最顶层父类的初始化块,最顶层父类的构造器,再依次往下,直到当前类。