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 里加了一个插件,解决了报错问题。

         
                net.alchim31.maven
                scala-maven-plugin
                3.3.1
                
                    
                        scala-compile-first
                        process-resources
                        
                            add-source
                            compile
                        
                    
 
                    
                        compile
                        
                            compile
                            testCompile
                        
                    
                
                
                    ${scala.version}
                
            

完整pom插件如下:

    
        
 
            
                net.alchim31.maven
                scala-maven-plugin
                3.3.1
                
                    
                        scala-compile-first
                        process-resources
                        
                            add-source
                            compile
                        
                    
 
                    
                        compile
                        
                            compile
                            testCompile
                        
                    
                
                
                    ${scala.version}
                
            
 
            
                org.scala-tools
                maven-scala-plugin
                
                    
                        
                            compile
                            testCompile
                        
                    
                
                
                    ${scala.version}
                    
                        -target:jvm-1.8
                    
                
            
            
                
                
                    
                    
                    
                        
                    
                
                
                    
                        
                        
                        
                            
                        
                    
                
            
        
    

你可能感兴趣的:(大数据,分布式技术,java,scala,开发语言)