java初始化顺序

来源:互联网 发布:淘宝店铺过期不存在 编辑:程序博客网 时间:2024/05/20 06:52

java初始化顺序

先贴一段代码,结果输出弄明白了,就不用往下看了
class Meal{    Meal(){        System.out.println("Base constructor: Meal()");    }    static String wsp=printf("Base static field");    static String printf(String s){        System.out.println(s);        return s;    }    int money=getInt(7);    int getInt(int x){        System.out.println("Base non-static field");        return x;    }}class Bread{    public Bread(){        System.out.println("Super non-static field");    }}public class Rewrite extends Meal{    private Bread b=new Bread();    public Rewrite(){        System.out.println("Super constructor: Rewrite()");    }    static String wsp=Meal.printf("Super static field");    public static void main(String[] args) {        new Rewrite();    }}//Output:可以说明大部分情况了~Base static fieldSuper static fieldBase non-static fieldBase constructor: Meal()Super non-static fieldSuper constructor: Rewrite()
    首先是静态变量(域或者方法),它随着类的编译一起被初始化,当读到 public class Rewrite 时就会被初始化,毕竟是不依赖于对象的类变量;    但由于Rewrite 后又有extends关键字,编译器会去先编译基类;毕竟导出类中的**静态变量很有可能会依赖于基类终端静态变量**     然后,全部基类的静态变量都初始化完毕后,调用导出类(Rewrite)的构造器,然后调用基类的构造器(super());    在基类中,构造器初始化之前,类内的非静态变量进行初始化;即使变量定义散步在方法定义之间,它们仍会在任何方法(包括构造器)被调用之前得到初始化(?感觉TIJ4描述有点问题)    所有基类构造器都初始化完毕,就可以对当前导出类进行初始化了。输出显示确实是按照这样的顺序执行的;    个人理解,如有不正确的地方还请多多指点^_^
原创粉丝点击