我的枚举看起来像这样:

public enum SignMethod {

    MICROSOFT("Microsoft"),XML("Xml"),HDR("Hdr"),JAVA1("Java1");

    private final String name;
    private ArrayList<Server> servers = new ArrayList<>();
    private HashSet<String> fileTypes = new HashSet<>();

    public static void main(String... args) {
        System.out.println(MICROSOFT.getName()+" "+MICROSOFT.getServers()+ " " + MICROSOFT.getFileTypes());
        System.out.println(ServerAndSignMethodInitialiser.getServers(SignMethod.MICROSOFT));
        System.out.println(SignDataInitialiser.getFileTypesList(SignMethod.MICROSOFT));
    }

    private SignMethod(String name) {
        this.name = name;
        this.servers = ServerAndSignMethodInitialiser.getServers(this);
        System.out.println(servers);
        this.fileTypes = SignDataInitialiser.getFileTypesList(this);
        System.out.println(fileTypes);
    }
}


我正在尝试通过静态初始化程序类初始化服务器变量,该类具有一个从SignMethod枚举映射到服务器ArrayList的映射。但是,当我在构造函数中初始化后立即打印服务器时,其打印为null。将构造函数中的“ this”传递给其他方法是否存在一些问题。

public static ArrayList<Server> getServers(SignMethod signMethod) {
    System.out.println(signMethod);
    return signmethodToServerMap.get(signMethod);
}


当我在getServers方法中优先使用signMethod时,其打印方式为“ MICROSOFT”等。

最佳答案

猜猜这是鸡蛋和鸡肉的问题。


每个枚举值的构造函数都需要调用getServers(SignMethod)方法。
getServers(SignMethod)方法在Map中查找。
Map具有枚举值作为键。因此,不能在枚举值的构造函数完成之前填充它。


目前,我可以想到三种解决方案:


保持枚举简单,不要尝试在其中存储其他信息。然后,您可以完全依靠signmethodToServerMap来存储服务器。
无需静态初始化地图,只需将Server列表存储在枚举中即可。
使Map独立于枚举。例如,从String映射到Server并说

this.servers = ServerAndSignMethodInitialiser.getServers(this.name);

10-06 13:16