Java 泛型不兼容的类型(不存在类型变量 T 的实例)

2022-09-01 17:44:17

这基本上是我第一次接触Java泛型类型,我无法弄清楚下面的代码有什么问题。

我有一个带有静态函数usng泛型类型的帮助器类,它应该从输入列表中返回对象列表,这些对象在索引处的某些对象周围(我还没有测试它,如果它工作正常与否,这里不是问题):HelperinRangerangeindex

public class Helper {
public static <T> List<T> inRange(List<T> list, int index, int range) {
    List<T> res = new ArrayList<T>();
    int N = list.size();
    assert(index < N);
    if (N == 0)
        return res;
    int i, j;

    /* right range */
    i = (index + 1) % N;
    j = 0;
    while (i != index && j < range) {
        res.add(list.get(i));
        i = (i + 1) % N;
        j++;
    }

    /* left range */
    i = (N + index - 1) % N;
    j = 0;
    while (i != index && j < range && !res.contains(list.get(i))) {
        res.add(lista.get(i));
        i = (N + i - 1) % N;
        j++;
    }

    return res;
}
}

然后我想在类中使用它:

import java.util.ArrayList;

public class StrategyA extends StrategyB {
public Decision makeDecision(GameView gameView, Action action, View playerView) {
    int pos = gameView.activePlayersViews().indexOf(playerView);
    assert(pos != -1);

    ArrayList<View> inRange = Helper.inRange(gameView.activePlayersViews(), pos, 
            playerView.range());
    // todo ...
    return new Decision(Decision.KindOfDecision.DO_NOTHING, 0);

}
}

其中 是 类型 。gameView.activePlayersView()ArrayList<View>

然后从我的IDE(IntelliJ IDEA)上呼叫我得到inRange(..)

Error:(8, 56) java: incompatible types: no instance(s) of type variable(s) T exist so that java.util.List<T> conforms to java.util.ArrayList<View>

即使我直接将泛型类型更改为我仍然收到此错误TView


答案 1

ArrayList是接口的实现。
因此,所有实例都是实例,但不一定是 所有实例。ListArrayListListListArrayList

所以当你调用这个方法时:

public static <T> List<T> inRange(List<T> list, int index, int range) {

您无法将其结果分配给 ,因为您正在执行:ArrayList

ArrayList<View> inRange = Helper.inRange(...);

继续按接口编程并在两侧使用:List

List<View> inRange = Helper.inRange(...);

答案 2

最小化您的示例,例如(使用模板化列表类型的整数):

class Ideone
{
    public static void main (String[] args) throws java.lang.Exception
    {
        List<Integer> list = new ArrayList<Integer>();
        ArrayList<Integer> inRange = Helper.inRange(list, 0,1);
    }
}

class Helper {
    public static <T> List<T> inRange(List<T> list, int index, int range) {
        List<T> res = new ArrayList<T>();
        return res;
    }
}

然后,即使您将模板类型从图片中剔除:

ArrayList inRange = Helper.inRange(list, 0,1);

public static List inRange(List list, int index, int range) { ... }

你看到当帮助器静态方法返回一个List时,你正在尝试将其分配给ArrayList,这就是你的问题,因为ArrayList是List的具体实现,但你不能将泛型List的引用分配给ArrayList的具体实现。

只需更改为:

List<View> inRange = Helper.inRange(gameView.activePlayersViews(), pos, 
        playerView.range());

你很高兴去:https://ideone.com/MXZxqz


推荐