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()还处在上一次值的位置(这就像是我右脚只迈了一步,但是我左脚迈了两步,两脚不同步,一脚已经到达终点,另一脚还没跟上来的情况)