gpt4 book ai didi

Java 循环枚举初始化 - 发生了什么以及为什么会发生?

转载 作者:行者123 更新时间:2023-11-30 04:57:29 25 4
gpt4 key购买 nike

Possible Duplicate:
Java Enums: Two enum types, each containing references to each other?

在我们的代码中,我们遇到了一些与枚举有关的奇怪的 NPE。当我搜索时,我发现(或多或少)以下案例:

public class EnumTest {

public static void main(final String[] args){
System.out.println("------ START ----- ");
System.out.println("BeezleBubs FOO's rockSteady is: " + BeezleBub.FOO.rockSteady);
System.out.println("RockSteady BAR's beezleBub is: " + RockSteady.BAR.beezleBub);
System.out.println("------ END ----- ");
}

public enum RockSteady {
BAR(BeezleBub.FOO);

public final BeezleBub beezleBub;
private RockSteady(final BeezleBub beezleBub) {
this.beezleBub = beezleBub;
System.out.println("Constructing RockSteady, beezleBub = " + beezleBub);
}

}

public enum BeezleBub {

FOO(RockSteady.BAR);

public final RockSteady rockSteady;

private BeezleBub(final RockSteady rockSteady) {
this.rockSteady = rockSteady;
System.out.println("Constructing BeezleBub, rockSteady = " + rockSteady);
}

}
}

由于某种原因,结果很尴尬。运行时,此测试输出:

------ START ----- 
Constructing RockSteady, beezleBub = null
Constructing BeezleBub, rockSteady = BAR
BeezleBubs FOO's rockSteady is: BAR
RockSteady BAR's beezleBub is: null
------ END -----

另一件事是,当您切换调用枚举的 System.out.prinln() 语句时,枚举的初始化也会发生变化。结果是:

------ START ----- 
Constructing BeezleBub, rockSteady = null
Constructing RockSteady, beezleBub = FOO
RockSteady BAR's beezleBub is: FOO
BeezleBubs FOO's rockSteady is: null
------ END -----

有人对发生的事情有清楚的解释吗?它与状态和秩序有关,但我不能完全确定它......

最佳答案

在 Java 中,类是延迟加载和初始化的。这意味着,无论您尝试首先打印哪个类的属性,都会先加载并初始化。一般来说,如果您有类的相互递归初始化程序,那么您应该避免在所有构造函数完成之前检查它们的属性。

原因很简单,Java 没有可以执行的初始化步骤序列来确保所有可能用途的原子初始化。

顺便说一句,这与枚举无关,它可能发生在普通的旧 Java 类中。

关于Java 循环枚举初始化 - 发生了什么以及为什么会发生?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8076534/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com