我正在尝试创建一个服务容器,并想知道如何反映调用该方法时使用的类型。见下文:
public class ServiceContainer {
HashMap<Type, Object> services;
public ServiceContainer() {
services = new HashMap<Type, Object>();
}
public <T> void addService(Type t, T object) {
services.put(t, object);
}
public <T> void addService(T object) {
Type type = typeof(T);
services.put(type, object);
}
}
我更喜欢使用第二个addService,但如果这不可能,那么可以依赖它。
编辑:我认为我找到了addService的解决方案,但是现在有另一种方法无法以同样的方式解决:public class ServiceContainer {
HashMap<Class, Object> services;
public ServiceContainer() {
services = new HashMap<Class, Object>();
}
public <T> void addObject(T object) {
Class type = object.getClass();
services.put(type, object);
}
public <T> boolean containsService() {
}
public <T> T getService() {
services.get(
ServiceContainer.class.getMethod( "getService", null )
.getGenericParameterTypes()[0] );
}
}
我现在正在黑暗中拍摄,我应该仔细阅读一些文档...
答案 0 :(得分:5)
除非您在类名(而不是Type
)上进行映射,否则无法使用第二个addService - 例如
public class ServiceContainer {
HashMap<Class, Object> services;
public ServiceContainer() {
services = new HashMap<Class, Object>();
}
public <T> void addService(Class<T>, T object) {
services.put(t, object);
}
public <T> void addService(T object) {
Class type = object.getClass();
services.put(type, object);
}
}
typeOfT()不起作用的原因是因为java泛型在编译后被“擦除”。实际上,只有'语法糖'才能使用ocmpiler来检查类型赋值中的明显错误。
编辑:自问题发生变化:实现containsService方法:
public boolean containsService(String classname) {
return services.get(Class.forName(classname)) != null;
}
我会说,鉴于您正在做的事情非常普遍,请了解如何使用依赖注入库来执行服务注册和检索。我听到有关Spring和google Guice的好消息。