我有一个界面ServiceArgument
,用于定义size()
承诺。
public interface ServiceArgument {
public int size ();
}
我的一些enum
类型实现了此接口
public enum StringCode implements ServiceArgument {
FOO,
BAR,
BACON,
public int size() {
return values().length;
}
}
我的一些课程遵循EnumService
抽象类。
public abstract class EnumService {
abstract void query (Enum<? extends ServiceArgument> e);
}
为了将其包装起来,一些类扩展了这个抽象类:
public class ServiceTranslation extends EnumService implements Serializable {
/**some code and ctors and transient stuff etc **/
@Override
void query (Enum<? extends ServiceArgument> e) {
//line that matters :
if (e.ordinal() >= e.size()) {
throw InvalidStringCodeAsked();
}
}
我的问题是,我不能在最后一行使用e.size(),因为我不会在我的示例枚举中使用FOO.size()。 有没有办法:
1)专门化query
方法在EnumService
2)获取ServiceTranslation.query(MYSTERIOUS.ENUM)
中调用的Enum的具体类型,以便能够调用ConcreteENUM.size()
。甚至是ConcreteEnum.values()。长度,它都是一样的。
3)甚至过滤掉非正确枚举类型的所有内容,直接抛出InvalidEnumeratedTypeException
方法覆盖,但我不熟悉多重覆盖。
4)我没有想到的东西
编辑:评论中的@shmosel是正确的,即使我将错误的枚举作为参数,它也永远不会大于它的大小。没有必要将它与它的大小进行比较。
答案 0 :(得分:2)
这个怎么样?
public abstract class EnumService {
abstract <T extends Enum<T> & ServiceArgument> void query (T e);
}
public class ServiceTranslation extends EnumService implements Serializable {
@Override
<T extends Enum<T> & ServiceArgument> void query (T e) {
if (e.ordinal() >= e.size()) {
throw InvalidStringCodeAsked();
}
}
}