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

实例化子类时,父类与子类中的静态代码块、实例代码块、静态变量、实例变量、构造函数的执行顺序是怎样的?

代码执行的优先级为:

firest:静态部分

second:实例化过程

详细顺序为:

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

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

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

4.父类构造函数

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

6.子类构造函数

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

测试代码:

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;

}

}

调用代码:

new Thread(new Runnable() {

@Override

public void run() {

new Child();

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

new Child();

}

}).start();

执行结果:

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

11-03 20:02:03.35

0 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 ------ 子类构造函数

本文转自 一点点征服   博客园博客,原文链接:http://www.cnblogs.com/ldq2016/p/6626700.html,如需转载请自行联系原作者

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值