Java Scala 混合編程導致 編譯失敗 ,【找不到符號】問題解決


大致就是 工程里分了 java 代碼 和 scala 代碼。

 

然后在java代碼中 引用了 scala 的代碼。
運行不報錯。
但是打包就是一直報錯。

[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project spark-auth: Compilation failure
[ERROR] /Users/hulb/project/dipper/spark-authorizer/spark-auth/src/main/java/org/apache/spark/sql/optimizer/BaseAuthorizeImpl.java:[4,47] 找不到符號
[ERROR] 符號: 類 Authorizer
[ERROR] 位置: 程序包 org.apache.spark.sql.catalyst.optimizer

如果直接把java代碼放在 scala 里面,編譯時會直接忽略這個類,不參與編譯。

在pom 里加了一個插件,解決了報錯問題。

<plugin>
<groupId>net.alchim31.maven</groupId>
<artifactId>scala-maven-plugin</artifactId>
<version>3.3.1</version>
<executions>
<execution>
<id>scala-compile-first</id>
<phase>process-resources</phase>
<goals>
<goal>add-source</goal>
<goal>compile</goal>
</goals>
</execution>

<execution>
<phase>compile</phase>
<goals>
<goal>compile</goal>
<goal>testCompile</goal>
</goals>
</execution>
</executions>
<configuration>
<scalaVersion>${scala.version}</scalaVersion>
</configuration>
</plugin>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM