我试着更有效地使用枚举。
第一个问题是,如果我像下面这样使用,它是某种战略模式吗?调用方调用,如Type.get(0).isSkip()
public enum Type {
TYPE_A(0) {
@Override
public boolean isSkip() {
return true;
}
abstract public boolean isSkip();呼叫方呼叫
Type.get(0).isSkip()第二个问题是最近我发现了类似的枚举抽象工厂模式
interface IType {
public boolean isSkip();
}
public class Type {
class Type_A implements IType {
public Type_A() {}
@Override public boolean isSkip() {
}
}
}而Enum课程只是做工厂的事情,比如
interface IFactory
{
public IType get();
};
public enum EnumAbstractFactory implements IFactory{
A {
public IType get() {
return new Type_A();
}
}抽象工厂方法比Enum类有什么更好的优点?哪一个是更好的解决方案?
发布于 2022-08-19 21:20:21
发布于 2022-08-20 13:41:08
我发现很难理解为什么您会以您声明的方式使用任何一种形式作为“抽象工厂”--如果您用更多的细节编辑这个问题,就像您的代码所暗示的那样,它将决定某种类型的"isSkip()“功能。
第一种形式不是声明枚举的一种非常易读的方式:@Override isSkip()会导致不必要的新匿名类,而且您无法从枚举派生类,因此abstract public boolean isSkip()声明没有意义。
作为另一种选择,我建议一个简明的定义,将isSkip功能设置为构造函数参数,或者使用枚举映射,或者使用方法isSkip(),如下所示:
enum Type {
TYPE_A, TYPE_B, TYPE_C; // etc
public boolean isSkip() {
return this == TYPE_A;
};
}这样,您就可以使用Type.XYZ.isSkip()进行引用。您还可以在枚举上使用IType接口,如下所示,如果您需要共享此isSkip功能的其他类:
enum Type implements IType {
...
}https://stackoverflow.com/questions/73418511
复制相似问题