java map使用迭代器遍历时执行删除元素报空指针异常

我建立了两个Map,其流程是遍历两个map,将map1中value值与map2中相同,但是K值不同的数据查找出来。然后把这条数据从Map2中删除。我使用迭代器在执行移除的时候是报空指针(java.lang.NullPointerException)的错。
请教一下代码问题错误在哪?
代码如下:

            for (Map.Entry<String, DBdata> entry1 : map1.entrySet()) {
            //初始化数据
                            String code1 = entry1.getKey();
                            DBdata data1 = entry1.getValue();
                            Iterator<Map.Entry<String, DBdata>> iter = map2.entrySet().iterator();                               
                            while (iter.hasNext()) {
                                Map.Entry<String, DBdata> entry2 = iter.next();
                                String code2 = entry2.getKey();
                                DBdata data2 = entry2.getValue();
                                if (code1.equals(code2)) {
                                    continue;
                                 }
                                if (data1.get_URL() != null) {
                                     if (data1.get_URL().equals(data2.get_URL())) {
                                          if (data1.get_USER_CODE() != null) {          
                                                 if (data1.getBUSINESS_CODE().equals(data2.getBUSINESS_CODE())) {
                                                     if (data1.getSYSTEM_CODE().equals(data2.getSYSTEM_CODE())) {
                                                      LOG.info("移除该数据 ");
                                                      iter.remove();
                                }
                            }


                        }
                        
                    }
                }
                
            }
        }
阅读 6.4k
6 个回答

感觉报空指针异常的不是这段代码

麻烦贴一下具体的异常

debug一下就好了

Map.Entry<String, DBdata> it = iter.next();
这一行放循环里面会不会好一点
为什么对iter做那么多next()操作,你确定不是操作了n/2条数据?

谢邀,能确定是iter.remove();这行代码抛出的异常么,个人感觉应该不会是这一行,把异常堆栈信息贴出来吧,如果容器数据量不大,debug一下应该就能查出来。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题