我正在重写一些代码,并且我已经决定了重新创建类的方式,因为有固定数量的工作表,我将它们创建为枚举。这是基于构建器模式与伸缩式构造器的可读性的决定。
我正在抓取一些 .xls 文件的代码,添加标题(并从其他 .xls 文件中读取一些),也许还有一些子表。然后,它以特定方式将各种这些工作表合并在一起,以在主 Excel 工作簿上制作选项卡。我的问题是某些工作簿选项卡采用不同数量的工作表是参数。我正在尝试应用构建器模式。这是我正在尝试编写的那种代码:
public enum workBookSheet {
mySheet1("Name1","mainSheet1.xls",true,1).addSubSheet("pathToSubSheet1.xls"),
mySheet2("Name2","mainSheet2.xls",true,2).addHeaderSheet("pathToHeaders.xls").addSubsheet("pathtoSubSheet2.xls");
private String tabName;
private String mainSheetName;
private Boolean available;
private Integer order;
private String subSheetName;
private String headerSheetName;
private workBookSheet(String tabName, String mainSheetName, Boolean available, Integer order){
this.tabName = tabName;
this.mainSheetName = mainSheetName;
this.available = available;
this.order = order;
}
public workBookSheet addSubSheet(String subSheetName){
this.subSheetName = subSheetName;
return this;
}
public workBookSheet addHeaderSheet(String headerSheetName){
this.headerSheetName = headerSheetName;
return this;
}
}
java给我的错误似乎是说Java希望我的枚举声明(顶部的“枚举构造函数”的逗号分隔列表)只有构造函数,而不是其他方法。我可以毫无怨言地将这些方法移到下面的“构建器”方法中。
public void buildSheets(){
mySheet1.addSubSheet("pathToSubSheet1.xls");
mySheet2.addHeaderSheet("pathToHeaders.xls").addSubSheet("pathtoSubSheet2.xls");
}
这是在枚举上实现构建器模式的唯一方法吗?它确实需要我运行一个单独的方法,这并不太麻烦。不过,它确实感觉我正在打破这种模式(我想,如果这行得通,那并不是一件坏事。)
注意,我环顾四周,看看是否有其他人在 SO 或网络上的其他地方问过这个问题。我发现的最接近的是关于枚举和工厂的问题,但这并不能完全回答我的问题。另外我知道这不是构建器模式,因为我没有一个单独的类,然后接受一个创建新枚举的 build() 方法。我想这是我最初设计中问题的根源,但我对 Java 还比较陌生。
那么有没有更好的方法在 Java 枚举上使用构建器模式?还是我“足够接近”?