有次系统维护我做了一个很小的改动,却出了出乎意料的错误,很是困惑,
原程序示例如下:
- for(int i =0;i<resultList.size();i++){
- Map resultMap = new HashMap();
- resultMap = (Map)resultList.get(i);
- resultGetList.add(resultMap);
- }
- System.out.println("resultGetList = "+resutlGetList);
为了提高程序的效率我认为,第二行不应该放到循环的里面,因为放到里面的话每次循环总汇新建对象,影响速度,所以我改善后如下:
- Map resultMap = new HashMap();
- for(int i =0;i<resultList.size();i++){
- resultMap = (Map)resultList.get(i);
- resultGetList.add(resultMap);
- }
- System.out.println("resultGetList = "+resutlGetList);
但是修改后的结果与预期的结果不同,可是我不清楚问题出在哪里,找了很久也没找出来,修改程序后输出的list总是最后一个map值的重复,这个让我很困惑,我猜测,List.add,是添加的对象,或者说是内存的地址而已,并不是把Map的值存了起来。
在优化程序效率时,作者尝试将Map实例移出循环,以减少每次迭代时的创建成本。然而,修改后的代码导致了输出结果的错误,表现为结果集仅包含最后一次迭代的Map值。本文探讨了List.add操作的行为及其对Map引用的影响。
538

被折叠的 条评论
为什么被折叠?



