错误:java:尝试运行Maven时出现java.lang.ExceptionInInitializerError com.sun.tools.javac.code.TypeTags

时间:2020-08-16 14:56:33

标签: java maven pom.xml

我是Maven的新手,但我想使用它来运行简单的deeplearing4j程序。添加所有必要的依赖项后,我将得到以下内容:

Error:java: release version 5 not supported

按照this页上的说明进行操作后(将我的SDK,语言和目标字节代码更改为11)

enter image description here

enter image description here

我正在得到这个:

Error:java: java.lang.ExceptionInInitializerError
com.sun.tools.javac.code.TypeTags
Error:java: java.lang.ExceptionInInitializerError

我也尝试设置JDK 14,但出现相同的错误。这是我的pom.xml文件:

<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>Deep</artifactId>
    <version>1.0-SNAPSHOT</version>
    
    <properties>
        <maven.compiler.source>1.11</maven.compiler.source>
        <maven.compiler.target>1.11</maven.compiler.target>
        <dl4j.version>0.9.1</dl4j.version>
    </properties>

    <dependencies>

        <dependency>
            <groupId>org.nd4j</groupId>
            <artifactId>nd4j-native-platform</artifactId>
            <version>${dl4j.version}</version>
        </dependency>

        <dependency>
            <groupId>org.deeplearning4j</groupId>
            <artifactId>deeplearning4j-core</artifactId>
            <version>${dl4j.version}</version>
        </dependency>

        <dependency>
            <groupId>org.datavec</groupId>
            <artifactId>datavec-api</artifactId>
            <version>${dl4j.version}</version>
        </dependency>
        
        <dependency>
            <groupId>org.nd4j</groupId>
            <artifactId>nd4j-api</artifactId>
            <version>1.0.0-beta3</version>
        </dependency>
        
        <dependency>
            <groupId>org.deeplearning4j</groupId>
            <artifactId>deeplearning4j-play_2.11</artifactId>
            <version>0.9.1</version>
        </dependency>
        
    </dependencies>

</project>

如果有人可以阐明我在这里做错了什么,我将不胜感激。

5 个答案:

答案 0 :(得分:5)

这是错误的。

<maven.compiler.source>1.11</maven.compiler.source>
<maven.compiler.target>1.11</maven.compiler.target>

在Java 1.9之后,版本命名已更改。在pom.xml中进行以下更改。

<maven.compiler.source>11</maven.compiler.source>
<maven.compiler.target>11</maven.compiler.target>

从10多个Java版本开始遵循相同的约定。

真正的问题是:库 org.deeplearning4j:deeplearning4j-core:jar:0.9.1:compile 中的一个依赖于 org.projectlombok:lombok:jar: 1.16.16:compile

因此这是Lombok的问题,他们在更高版本中修复了该问题。要查看所有传递依赖关系,您可以执行mvn dependency:tree并查看所引入库的所有传递依赖关系。

我已将以下依赖项包含在pom中,从而解决了该问题。

<dependency>
  <groupId>org.projectlombok</groupId>
  <artifactId>lombok</artifactId>
  <version>1.18.2</version>
  <scope>provided</scope>
</dependency>

答案 1 :(得分:3)

使用jdk 10编译java8源代码时也出现这个错误。

maven compile error

将环境变量 JAVA_HOME 更改为 jdk8 主目录后,此错误消失。

答案 2 :(得分:1)

将此添加到 pom.xml:

<dependency>
  <groupId>org.projectlombok</groupId>
  <artifactId>lombok</artifactId>
  <version>1.18.20</version>
  <scope>provided</scope>
</dependency>

答案 3 :(得分:0)

如果您使用 jdk8 运行您的项目并且仍然面临同样的错误。 请按照以下 2 个步骤操作。

  1. 检查您是否能够从 IntelliJ 的 Maven 栏而不是从终端执行您的 Maven 项目。
  2. 如果您的项目已构建,请检查您的 JAVA_HOME 是否设置正确。 (在我的情况下,我从 bash 切换到 zsh,并且 JAVA_HOME. 未设置)

答案 4 :(得分:0)

在运行应用程序 Intellij 时出现此问题的原因可能是您尚未在 IDE 中配置项目 SDK 设置。

enter image description here