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

静态代码块的执行顺序(类中含有本类对象)

2015-06-29 18:43 232 查看
public class ExA {
private static ExA a = new ExA();
static {
System.out.println("父类--静态代码块");
}

public ExA() {
System.out.println("父类--构造函数");
}

{
System.out.println("父类--非静态代码块");
}

public static void main(String[] args) {
new ExB();
}
}

class ExB extends ExA {
private static ExB b = new ExB();
static {
System.out.println("子类--静态代码块");
}
{
System.out.println("子类--非静态代码块");
}

public ExB() {
System.out.println("子类--构造函数");
}
}
</pre><pre name="code" class="java">执行结果:
父类--非静态代码块
父类--构造函数
父类--静态代码块
<pre name="code" class="java">父类--非静态代码块
父类--构造函数
子类--非静态代码块
子类--构造函数
子类--静态代码块
<pre name="code" class="java">父类--非静态代码块
父类--构造函数
子类--非静态代码块
子类--构造函数








先加载类字节码,静态部分(静态代码快/静态成员变量)随着类的加载而加载,最后在去执行主函数中的代码(即创建对象引用,初始化成员变量等)。在静态部分是顺序执行的,即按照类文件中的代码编写先后顺序执行。

在你的第二段代码中是先有个静态成员变量并初始化了,对象在初始化的过程中会牵扯到非静态代码块和构造函数的执行,接下来才是静态代码快,在接下来就是主函数的执行了。所以会造成先执行非静态代码块,再执行静态代码块的 “假象”。

其实质还是先执行静态部分,再执行创建对象,初始化成员变量等再非静态部分,只是静态成员变量的初始化牵扯到了非静态部分的执行。

类加载执行顺序:类字节码→静态代码块static{...}/静态成员变量→创建对象引用,初始化成员变量

其实说白了 就是先加载类 后加载对象, 而静态部分随着类的加载而加载 优先于主函数

你代码中 把本类对象放到了类的成员位置,作为一个成员变量而存在

使其随着类一起加载,但是对象在类加载的时候尚不存在,为了向前拓宽 该对象的出现时间,所以给他加了一个static。

导致 该对象在加载类的过程中就被一起加载 并初始化了,这个时候的初始化调用了 非静态代码块 和构造函数。

这才出现了非静态出现在静态之前

本质原因还是 对象被作为类的成员随类一起加载了,而静态紧随其后被加载
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: