一个奇怪的问题,从泛型为Integer的Set中取到的遍历取到的值为String

public ResponseResult putAllAnswer(Map<Integer, String> map) {
        Set<Integer> testIds=map.keySet();
        List<Integer> errorAnswer=new LinkedList<Integer>();
        for(Integer testId:testIds){
            Test test=testMapper.selectByPrimaryKey(testId);
            if(map.get(testId).equals(test.getRightAnswer())){
                continue;
            }else{
                errorAnswer.add(testId);
            }
        }
}

public ResponseResult putAllAnswer(HashMap<Integer, String> map) {
        Set<Integer> testIds=map.keySet();
        List<Integer> errorAnswer=new LinkedList<Integer>();
        Iterator<Integer> iter=testIds.iterator();
        while(iter.hasNext()){
            System.out.println(iter.next().getClass());
            Integer testId=iter.next();

        }
}

代码如上,在执行到for循环内时,testId无法接受testIds中的数据,显示类型转换错误,String无法转换为Integer类型,非常奇怪,即使是通过Iterator遍历也无法获取set集合中的值,始终显示String无法转换为Integer类型的报错,甚至在无法通过getClass方法来获取对象的类型信息,执行该语句也会报错

Set testIds=map.keySet();

这一行改为 Set testIds=map.keySet();

原因就是key不是Integer,没别的原因.
你这个错误相当于

    public static void main(String[] args) {
        Map map = new HashMap();
        map.put("a","a");
        Map<Integer,String> m = map;
        Set<Integer> set = m.keySet();
        for (Integer integer : set) {
            System.out.println(integer);
        }
    }

System.out.println(iter.next().getClass());
Integer testId=iter.next();
第二个方法迭代了两次,这个可能会超过迭代器的边界。
从代码上看就这里有问题。

1.上面的类型转换错误,可能是你这个 Test test=testMapper.selectByPrimaryKey(testId);查询数据库出来的字段和bean类中的类型不匹配导致的
2.还有你有一个越界行为,循环一次调用一次iter.next()这个,代表取的是上一次取的接下来一个值,但是iter.hasNext()还处在上一次值的位置(这就像是我右脚只迈了一步,但是我左脚迈了两步,两脚不同步,一脚已经到达终点,另一脚还没跟上来的情况)