上述所给代码出错,显示SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/D:/apache-maven-3.6.1/maven_repository/org/slf4j/slf4j-reload4j/1.7.36/slf4j-reload4j-1.7.36.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: Found binding in [jar:file:/D:/apache-maven-3.6.1/maven_repository/org/slf4j/slf4j-log4j12/1.7.25/slf4j-log4j12-1.7.25.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation. SLF4J: Actual binding is of type [org.slf4j.impl.Reload4jLoggerFactory] log4j:WARN No appenders could be found for logger (org.apache.hadoop.metrics2.lib.MutableMetricsFactory). log4j:WARN Please initialize the log4j system properly. log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info. Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0 at WordCountTest.SortNumbers.main(SortNumbers.java:48)
时间: 2023-08-28 18:05:57 浏览: 217
解决SLF4J: Failed to load class "org.slf
这个错误是因为项目中引入了多个 SLF4J 绑定,造成了冲突。可以通过在项目的 pom.xml 文件中排除其中一个冲突的依赖来解决此问题。例如,如果你想排除 slf4j-log4j12 的依赖,可以按照以下方式操作:
```
<dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-mapreduce-client-core</artifactId>
<version>2.7.1</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
```
在排除依赖后,重新编译和运行程序,就可以避免上述错误了。此外,log4j:WARN No appenders could be found for logger 的警告信息可能是因为没有正确配置 log4j,可以参考警告信息中提供的链接来了解如何配置 log4j。最后,java.lang.ArrayIndexOutOfBoundsException 错误可能是因为程序中访问了数组的越界元素,需要检查程序中的数组访问代码是否正确。
阅读全文