这是一个简单的例子,它演示了我正在遇到的与类型相关的问题.我有一个这样的课程:
public abstract class AbstractHandler {
...
public abstract Class handledType();
}
然后我有这个实现:
public class ConcreteHandler extends AbstractHandler>> {
@Override
public Class>> handledType() {
//what do I return here?!
}
}
我不能返回Map< String,List< Thing>> .class,因为这在语法上甚至不是有效的.我尝试使子类型中的泛型类型参数为HashMap< String,List< Thing>>然后返回新的HashMap< String,List< Thing>().getClass(),但是不起作用,因为Class< T> #getClass()的返回类型是Class&延伸T.我从Guava看了TypeToken,而getRawType方法似乎有希望,但是它返回Class超级T.
我有一个解决方法,暂时看起来像这样:
public class ThingListMap {
private Map> thingListMap;
...
}
我只是使用ThingListMap作为通用类型参数.
另一个可能的解决方法是执行强制转换:
public Class>> handledType() {
return (Class>>) new HashMap>().getClass();
}
有没有更优雅的方式来做到这一点?
编辑:响应其中一个答案,我不能改变的handleType方法的签名,因为我不拥有或控制其源.