我有一个接口(interface) Moded
.这些方法是 getMode()
, setMode( Enum<?> mode )
.
它还有一个方法getMode( Object key )
,用于在类具有多种模式时识别实现类时的“模式类型”(例如,OPEN/CLOSED 是一种状态,但 COMMAND_MODE/QUERY_MODE/OTHER_MODE 是另一种状态,即模式的“二维”)。
然后实现类将使用 enums
提供每种模式类型的可能值。
想法是getMode( Object key )
传递了一个键,实现类使用该键来标识要查找其值的模式类型。但是为了使它更好,如果你总是必须使用 Enum
将是理想的。类对象作为键。无论如何你都可以这样做,但为了强制执行它,我尝试更改为 getMode( Class<Enum<?>> key )
.
出于某种原因,假设我有一个类 IndexManager
实现Moded
, 它包含一个 enum
像这样:
enum MANAGER_MODE {
COMMAND_MODE, QUERY_MODE, OTHER_MODE
}
我实现的方法看起来像这样:
@Override
public Enum<?> getMode(Class<Enum<?>> key ) throws Exception {
if( key.equals( IndexManager.MANAGER_MODE.class )){
return managerMode;
}
...
...然后我试试这个:
indexManager.getMode( IndexManager.MANAGER_MODE.class )
我在 Eclipse 中收到消息
The method getMode(Class<Enum<?>>) in the type IndexManager is not applicable for the arguments (Class<IndexManager.MANAGER_MODE>)
然而这说“真”:
String.format( "extends Enum? %s", Enum.class.isAssignableFrom( IndexManager.INDEX_MANAGER_MODE.class ))
稍后
事实上,Andreas 的回答更好(没有强制转换;如果需要,类型安全)。使用他的方法,你把
<T extends Enum<T>> T getMode(Class<T> key )
允许实现多模式类
和
<T extends Enum<T>> T getMode()
允许实现单模式类
最佳答案
尝试 getMode(Class<? extends Enum> key)
相反。
关于java - 将 Enum.class 作为参数传递?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41641596/