package test02;
public class ExecutionSequence {
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
Super su = new Sub();
su.tetsExpands();
}
}
class Super{
static String staticField = "父类静态属性";
static {
System.out.println(staticField);
System.out.println("父类静态代码块");
}
String instanceField = "父类实例属性";
{
System.out.println(instanceField);
System.out.println("父类实例代码块");
}
public static void staticMethods() {
System.out.println("父类静态方法");
}
public Super(){
System.out.println("父类构造方法");
}
public void tetsExpands() {
System.out.println("父类普通方法");
}
}
class Sub extends Super{
static String staticField = "子类静态属性";
static {
System.out.println(staticField);
System.out.println("子类静态代码块");
}
String instanceField2 = "子类实例属性";
{
System.out.println(instanceField2);
System.out.println("子类实例代码块");
}
public static void staticMethods() {
System.out.println("子类静态方法");
}
public Sub(){
System.out.println("子类构造方法");
}
public void tetsExpands() {
System.out.println("子类普通方法");
}
}
执行结果:
分析:父类引用指向子类,使用多态,su.tetsExpands(),调用子类的普通方法
1、类加载机制:调用子类方法触发类加载,先加载父类,执行父类的静态属性和静态代码块,再加载子类,执行子类的静态属性和静态代码块。
2、执行子类构造方法,先执行父类的构造方法,初始化父类实例属性,再执行父类动态(实例)代码块,最后回到父类构造方法中,执行构造方法中的代码。
3、执行子类构造方法,初始化子类实例属性,再执行子类动态(实例)代码块,最后回到子类构造方法中,执行构造方法中的代码。
4、父类与子类静态方法,只有通过类名调用才执行。如:Super.staticMethods();
拓展:
创建子类对象,调用子类的普通方法,为什么执行了父类中的静态属性和静态代码块?
由于Jvm类加载机制,在有继承关系的类中,先加载父类,再加载子类。