今天同事新建一个Maven项目遇到以下一个错误:
Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project demo: Fatal error compiling: java.lang.ExceptionInInitializerError: Unable to make field private com.sun.tools.javac.processing.JavacProcessingEnvironment$DiscoveredProcessors com.sun.tools.javac.processing.JavacProcessingEnvironment.discoveredProcs accessible: module jdk.compiler does not “opens com.sun.tools.javac.processing” to unnamed module @5af8bb51 -> [Help 1]
和同事一起Debug后发现,原来是POM中这个依赖引起的问题。

	<dependency>
		<groupId>org.projectlombok</groupId>
		<artifactId>lombok</artifactId>
	</dependency>`

查了一下相关的文档发现,从JDK-16开始加入了JEP396。JEP396是个什么东东?您可以点击上面的链接进去看一下详细的说明,简单的说就是对 JDK 内部大部分元素默认进行强封装,从而限制对它们的访问,而这个新功能造成lombok不工作。这个帖子中有讨论如何让lombok工作的方法,有兴趣的同学可以进去研究一下,这里就不多说了。找到问题原因后,解决问题就比较简单了。将JDK16换成JDK-8后就没有问题了,当然,如果你的项目可以不用lombok,在POM中移除对它的依赖用JDK16也没问题。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐