我发现自己在使用泛型时遇到了一种奇怪的情况,到目前为止这似乎是不可能的。我尝试在简单的类中隔离这种情况。我试图完成的是:一个调度句柄来处理数据包的服务类。每个处理程序都有一个数据包类型参数,因为每个数据包都应该有一个处理程序。服务类也有一个 Handler 类型参数,因为有几种类型的处理程序,因此不同的处理程序类型需要几个服务。这个描述可能不是很清楚,所以这里是我做的例子:
public abstract class Service<T extends Handler<?>> {
//Some random logic
//If only I could use T<E>
protected abstract <E extends Packet> void handle(T handler, E packet);
}
public class ServiceImpl extends Service<HandlerOne<?>> {
@Override
protected <E extends Packet> void handle(HandlerOne<?> handler, E packet) {
handler.handle("someString", packet); //ERROR
}
}
public interface Handler<E extends Packet> {
}
public interface HandlerOne<E extends Packet> extends Handler<E> {
void handle(Object someObject, E packet);
}
public class HandlerOneImpl implements HandlerOne<SomePacket> {
@Override
public void handle(Object someObject, SomePacket packet) {
}
}
public interface Packet {
}
public class SomePacket implements Packet {
}
有没有办法完成这样的事情,或者有什么建议?谢谢
编辑:这是来自 manouti 答案的修改后的代码(注意:为了清楚起见,我将 SomePacket 更改为 PacketOne)。我遇到的问题是创建 ServiceImpl 的实例。
public static void main(String[] args) {
HashMap<Class<? extends Packet>, HandlerOne<? extends Packet>> handlerMap = new HashMap<>();
handlerMap.put(PacketOne.class, new HandlerOneImpl());
ServiceImpl<Packet, HandlerOne<?>> s = new ServiceImpl<>(handlerMap);//ERROR
}
public static abstract class Service<E extends Packet, T extends Handler<E>> {
Map<Class<? extends Packet>, T> handlerMap;
public Service(Map<Class<? extends Packet>, T> handlerMap) {
this.handlerMap = handlerMap;
}
//Some random logic
//If only I could use T<E>
protected abstract void handle(T handler, E packet);
}
public static class ServiceImpl<E extends Packet, T extends HandlerOne<E>> extends Service<E, T> {
public ServiceImpl(Map<Class<? extends Packet>, T> handlerMap) {
super(handlerMap);
}
@Override
protected void handle(T handler, E packet) {
handler.handle("someObject", packet);
}
}