在跑MapReduce程序时,出现了Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)
分析过程:
从这些提示信息中可以获取如下信息:
1、错误发生在17行,找到对应行
2、发生错误的时候,下标的值为1
接下来分析为什么下标值为什么是1时出现越界,就可以解决了。
我们使用打断点的方式找到问题根源:
再出现问题的地方打上断点,然后DeBug方式运行调试,逐步分析,放行,等到出现异常
逐步分析,放行,等到出现异常
出现异常
查看数据源,发现存在脏数据
解决:删除脏数据(23-26行数据),重新启动,发现成功解决问题
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
之前文章写到这里就结束了,但是我看评论中还是有人问,再补充几句。
补充:关于数组越界分析思路:
第一: 问题的原因是数组下标越界了,例如数组的元素个数是5,下标的范围应该是0..4,如果访问数组的时候下标不是0..4就会报在这样的错误。
第二:代码提示错误行就是发生错误的数组。
解决的方法:
先确认数组下标的正确范围,然后再检查调用的时候使用的下标值。