0

我有这个问题

一种从一个类中删除不需要的细节并返回带有想要的对象的集合的方法。问题是我希望这个方法能够与不同的类一起工作(尽管它们基于一个抽象),所以我使用泛型类型。问题是,有一次我需要创建一个实例,这是不可能的。我寻找了一些出路,但它似乎不适用于我的情况。所以,代码如下

 private <T extends RestMandate> List<T> toRestMandate(List<CardMandate> mandates ) {
    List<T> restMandates = new ArrayList<>(mandates == null ? 0
            : mandates.size());
    if (mandates != null) {
        for (CardMandate mandate : mandates) {
             restMandates.add(new T(mandate));
        }
    }

    return restMandates;
}

RestMandate 是基类, CardMandate 是我获取信息。有任何想法吗?

4

3 回答 3

3

由于泛型类型参数在运行时被删除,因此您无法像尝试那样引用它。唯一的出路是类型标签参数+反射实例化。

更好的选择是重新设计您的解决方案来解决这个问题,而不依赖于泛型和类型标签。改为利用动态方法分派:添加一个方法,RestMandate该方法将返回转换为所需类型的对象。

于 2013-09-25T09:59:42.050 回答
3

由于Type Erasure, T 在运行时变为 Object 。你不知道它的真实类型了。

如果你有它的类,你仍然可以通过反射来实例化对象。为此,您必须将类赋予您的方法:

private <T extends RestMandate> List<T> toRestMandate(List<CardMandate> mandates, Class<T> clazz ) {
  ...
  for (CardMandate mandate : mandates) {
     /*
      * I get the constructor which needs one CardMandate and call it.
      * Note : I do not recommend this solution (no check at compile-time!). 
      * Like Marko Topolnik, I advise to redesign the solution.
      */
     restMandates.add(clazz.getConstructor(CardMandate.class).newInstance(mandate));
  }
  ...
}
于 2013-09-25T10:00:38.590 回答
1

要创建实例,您也需要Class<T>对象

private <T extends RestMandate> List<T> toRestMandate(List<CardMandate> mandates, Class<T> clazz) {
    //....
    T newInst = clazz.newInstance();

    //....
}
于 2013-09-25T09:58:23.293 回答