在它的抽象超类中使用泛型类型的子类?

Mar*_*kus 6 java generics abstract-class class

在我的代码中,a有以下抽象超类

public abstract class AbstractClass<Type extends A> {...}
Run Code Online (Sandbox Code Playgroud)

和一些儿童班一样

public class ChildClassA extends AbstractClass<GenericTypeA> {...}

public class ChildClassB extends AbstractClass<GenericTypeB> {...}
Run Code Online (Sandbox Code Playgroud)

我正在寻找一种优雅的方式,我可以通用的方式在抽象类中使用子类的泛型类型(GenericTypeA,GenericTypeB,...).

为了解决这个问题,我目前定义了这个方法

protected abstract Class<Type> getGenericTypeClass();
Run Code Online (Sandbox Code Playgroud)

在我的抽象类中实现了该方法

@Override
protected Class<GenericType> getGenericTypeClass() {
    return GenericType.class;
}
Run Code Online (Sandbox Code Playgroud)

在每个儿童班.

是否可以在我的抽象类中获取子类的泛型类型而不实现此帮助器方法?

BR,

马库斯

nai*_*kus 10

我认为这是可能的.我看到这被用在DAO模式和泛型中.例如考虑课程:

public class A {}
public class B extends A {}
Run Code Online (Sandbox Code Playgroud)

而你的通用类:

  import java.lang.reflect.ParameterizedType;
  public abstract class Test<T extends A> {

     private Class<T> theType;

     public Test()  {
        theType = (Class<T>) (
               (ParameterizedType) getClass().getGenericSuperclass())
              .getActualTypeArguments()[0];
     }

     // this method will always return the type that extends class "A"
     public Class<T> getTheType()   {
        return theType;
     }

     public void printType() {
        Class<T> clazz = getTheType();
        System.out.println(clazz);
     }
  }
Run Code Online (Sandbox Code Playgroud)

你可以有一个类Test1,用类B扩展Test(它扩展了A)

  public class Test1 extends Test<B>  {

     public static void main(String[] args) {
        Test1 t = new Test1();

        Class<B> clazz = t.getTheType();

        System.out.println(clazz); // will print 'class B'
        System.out.println(printType()); // will print 'class B'
     }
  }
Run Code Online (Sandbox Code Playgroud)

  • 它使用反射.首先它获取类的Generic超类(java.lang.reflect.Type),在我们的例子中它永远不会为null并且我们知道它是ParameterizedType,所以我们抛出它并调用方法getActualTypeArguents返回一个数组类型的实际类型参数,例如B. (2认同)