public class Main3 {
运行结果: 为了看到清楚,我特地标注了号,号的顺序就是程序执行的大致顺序,可以看出,static静态代码块是最开始执行的,其实static代码块是在类加载的时候就执行完毕了,但是Main3类首先加载,而且加载的时候有static修饰的main函数,也就是代码的入口,就直接开始执行,执行到B b = new B();----(2)的时候,就要去加载A类和B类(我尝试过把这句话去掉,去掉之后,A类和B类都不会加载,static的静态代码块更不会执行),加载A类的时候就执行了静态代码块,加载B类的时候同样执行了静态代码块,(A类和B类的加载顺序个人觉得是首先加载父类),然后我们来看看A类,从A类看出:一般代码块(6)>构造块(8)>构造函数(8),但是这个结论并不是正确的,我尝试过将(6)和(8)的顺序兑换,发现执行顺序也会兑换过来,所以一般代码块和构造块的优先级是一样的,执行顺序由代码顺序决定,但两者优先于构造函数执行,但是你将同样的方法用于B类,你发现B类的super函数却是最开始执行的,只能说明凡是有父类的类,子类的super函数是最开始执行的,其他的都先等super执行完毕之后,执行顺序和我刚才说的A类的就一样了
public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println("main start");----(1)
B b = new B();----(2)
System.out.println("main end");----(14)
}
public static void f(){
System.out.println(" main static f ");
}
}
public class B extends A{
D d = new D();----(10)
public B(){
super();----(5)
System.out.println("B()");----(13)
}
{
System.out.println("B class");----(12)
}
static{
System.out.println("static class B");----(4)
}
}
public class A {
C c = new C();----(6)
public A(){
System.out.println("A()");----(9)
}
{
System.out.println("A class");----(8)
}
static{
System.out.println("static class A");----(3)
}
public static void f(){
System.out.println("static f A");
}
}
public class C {
public C(){
System.out.println("C()");----(7)
}
}
public class D {
public D(){
System.out.println("D()");----(11)
}
}
运行结果: 为了看到清楚,我特地标注了号,号的顺序就是程序执行的大致顺序,可以看出,static静态代码块是最开始执行的,其实static代码块是在类加载的时候就执行完毕了,但是Main3类首先加载,而且加载的时候有static修饰的main函数,也就是代码的入口,就直接开始执行,执行到B b = new B();----(2)的时候,就要去加载A类和B类(我尝试过把这句话去掉,去掉之后,A类和B类都不会加载,static的静态代码块更不会执行),加载A类的时候就执行了静态代码块,加载B类的时候同样执行了静态代码块,(A类和B类的加载顺序个人觉得是首先加载父类),然后我们来看看A类,从A类看出:一般代码块(6)>构造块(8)>构造函数(8),但是这个结论并不是正确的,我尝试过将(6)和(8)的顺序兑换,发现执行顺序也会兑换过来,所以一般代码块和构造块的优先级是一样的,执行顺序由代码顺序决定,但两者优先于构造函数执行,但是你将同样的方法用于B类,你发现B类的super函数却是最开始执行的,只能说明凡是有父类的类,子类的super函数是最开始执行的,其他的都先等super执行完毕之后,执行顺序和我刚才说的A类的就一样了