DeBug调试解决在跑MapReduce程序时,出现Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)问题

时间:2024-04-09 18:53:09

在跑MapReduce程序时,出现了Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)

DeBug调试解决在跑MapReduce程序时,出现Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)问题

分析过程:

从这些提示信息中可以获取如下信息:

1、错误发生在17行,找到对应行

DeBug调试解决在跑MapReduce程序时,出现Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)问题

2、发生错误的时候,下标的值为1

接下来分析为什么下标值为什么是1时出现越界,就可以解决了。

我们使用打断点的方式找到问题根源:

再出现问题的地方打上断点,然后DeBug方式运行调试,逐步分析,放行,等到出现异常

DeBug调试解决在跑MapReduce程序时,出现Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)问题

逐步分析,放行,等到出现异常DeBug调试解决在跑MapReduce程序时,出现Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)问题

出现异常DeBug调试解决在跑MapReduce程序时,出现Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)问题

查看数据源,发现存在脏数据

DeBug调试解决在跑MapReduce程序时,出现Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)问题

解决:删除脏数据(23-26行数据),重新启动,发现成功解决问题

DeBug调试解决在跑MapReduce程序时,出现Caused by: java.lang.ArrayIndexOutOfBoundsException: 1(数组越界异常)问题

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------

之前文章写到这里就结束了,但是我看评论中还是有人问,再补充几句。

补充:关于数组越界分析思路:

第一: 问题的原因是数组下标越界了,例如数组的元素个数是5,下标的范围应该是0..4,如果访问数组的时候下标不是0..4就会报在这样的错误。

第二:代码提示错误行就是发生错误的数组。

解决的方法:

先确认数组下标的正确范围,然后再检查调用的时候使用的下标值。