确定泛型类型的类
在泛型编程领域内,确定泛型类型的类是必要的被利用。然而,由于泛型的本质,类型信息通常会在运行时被删除,这给以后检索它带来了挑战。
示例:
考虑以下泛型class:
public class MyGenericClass<T> { public void doSomething() { // ... T bean = (T)someObject.create(T.class); // ... } }
在上面的示例中,我们尝试通过传递类文字来创建类 T 的实例。但是,这将导致“类型参数 T 的类文字非法”错误,因为禁止尝试使用泛型类型作为类文字。
解决方法:
为了克服这一挑战,一个可行的解决方法是将泛型类型的类作为参数传递给静态方法。然后,此方法将使用反射 API 来实例化泛型类型。
public class MyGenericClass<T> { private final Class<T> clazz; public static <U> MyGenericClass<U> createMyGeneric(Class<U> clazz) { return new MyGenericClass<>(clazz); } protected MyGenericClass(Class<T> clazz) { this.clazz = clazz; } public void doSomething() { T instance = clazz.newInstance(); } }
通过遵循此方法,我们规避了使用泛型类型作为类文字的限制,确保必要的类型信息在运行时可用。虽然它可能是一个不优雅的解决方案,但它提供了一种在具有挑战性的上下文中确定泛型类型的类的方法,如原始示例中所示。
以上是如何在运行时确定泛型类型的类?的详细内容。更多信息请关注PHP中文网其他相关文章!