java泛型类强制转换

时间:2012-09-17 21:19:07

标签: java class generics

你好我有哈希映射值:

    private static final LinkedHashMap<Class<? extends Annotation> , Class<? extends AGenerator<?>>> annotationGeneratorMap = new LinkedHashMap<Class<? extends Annotation>, Class<? extends AGenerator<?>>>();

我的数字生成器看起来像:

public abstract class NumericGenerator<T extends Number> extends AGenerator<T>{


public NumericGenerator(Field field) {
    super(field);
    // TODO Auto-generated constructor stub
}

public T random() {
    // TODO Auto-generated method stub
    return null;
}

  }

当我需要将这个类放入hashmap时,我遇到了问题:

annotationGeneratorMap.put(GenerateNumeric.class, NumericGenerator.class);

在eclipse中我有错误,该方法不适用于参数???

但是:

        annotationGeneratorMap.put(GenerateNumeric.class, (Class<? extends AGenerator<?>>) NumericGenerator.class);

和@SuppressWarnings(“未选中”)很好..:/

我可以不施法吗? (Class<? extends AGenerator<?>>) NumericGenerator.class

3 个答案:

答案 0 :(得分:2)

使用Class<? extends AGenerator>代替

LinkedHashMap<
    Class<? extends Annotation>, 
    Class<? extends AGenerator> > annotationGeneratorMap = new LinkedHashMap<>()

在Java中,类可以表示原始类型,但不能表示泛型类型。

List有一个课程,但List<String>没有课程。

因此,您可以声明与Class<? extends List>等兼容的ArrayList.class,因为原始类型ArrayListList的子类型。

但是Class<? extends List<?>>没有多大意义,因为没有类是List<?>的子类型。

所有这一切都归功于擦除。

答案 1 :(得分:1)

编译时间检查不允许您这样做,除非您当然要进行投射。

有关泛型类型的信息在运行时丢失,而不是编译时。

答案 2 :(得分:1)

在版本1.7.0_02上编译时没有错误:

import java.util.*;
import java.lang.annotation.*;

interface AGenerator<T> {}

interface A extends Annotation {}
class X implements AGenerator<X> {}

class E7 {
    private static final LinkedHashMap<Class<? extends Annotation>, 
        Class<? extends AGenerator<?>>> annotationGeneratorMap 
        = new LinkedHashMap<Class<? extends Annotation>, 
                            Class<? extends AGenerator<?>>>();


    void foo() {
        annotationGeneratorMap.put(A.class, X.class);
    }

}