您的位置:首页 > 编程语言 > Java开发

Java父类与子类中静态代码块 实例代码块 静态变量 实例变量 构造函数执行顺序

2017-03-27 14:49 615 查看
实例化子类时,父类与子类中的静态代码块、实例代码块、静态变量、实例变量、构造函数的执行顺序是怎样的?

代码执行的优先级为:

firest:静态部分

second:实例化过程

详细顺序为:

1.父类静态代码块与父类静态变量(取决于代码书写顺序)

2.子类静态代码块与子类静态变量(取决于代码书写顺序)

3.父类实例变量与父类代码块(取决于代码书写顺序)

4.父类构造函数

5.子类实例变量与父类代码块(取决于代码书写顺序)

6.子类构造函数

在JVM加载完类以后,类在被使用的时候初始化,静态部分只在类初始化的时候执行一次。

测试代码:

[java] view plain copy

class Father {

Father() {

LogUtil.log(System.currentTimeMillis() + " ------ 父类构造函数");

}

static {

LogUtil.log(System.currentTimeMillis() + " ------ 父类静态代码块");

}

long x = getTime(" ------ 父类实例变量");

{

long time = System.currentTimeMillis();

LogUtil.log(time + " ------ 父类代码块");

}

static long y = getTime(" ------ 父类静态变量");

static long getTime(String who) {

long time = System.currentTimeMillis();

LogUtil.log(time + who);

return time;

}

}

class Child extends Father {

Child() {

LogUtil.log(System.currentTimeMillis() + " ------ 子类构造函数");

}

static long y = getTime(" ------ 子类静态变量");

static {

LogUtil.log(System.currentTimeMillis() + " ------ 子类静态代码块");

}

{

long time = System.currentTimeMillis();

LogUtil.log(time + " ------ 子类代码块");

}

long x = getTime(" ------ 子类实例变量");

static long getTime(String who) {

long time = System.currentTimeMillis();

LogUtil.log(time + who);

return time;

}

}

调用代码:

[java] view plain copy

new Thread(new Runnable() {

@Override

public void run() {

new Child();

LogUtil.log("分隔符 ------ 分隔符");

new Child();

}

}).start();

执行结果:

[plain] view plain copy

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 父类静态代码块

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 父类静态变量

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 子类静态变量

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 子类静态代码块

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 父类实例变量

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 父类代码块

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 父类构造函数

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 子类代码块

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 子类实例变量

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 子类构造函数

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 分隔符 ------ 分隔符

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 父类实例变量

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 父类代码块

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523353 ------ 父类构造函数

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523354 ------ 子类代码块

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523354 ------ 子类实例变量

11-03 20:02:03.350 7533-7881/? E/AKADDEMO: 1478174523354 ------ 子类构造函数
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐