scala和maven整合

1.scala和maven如何整合

    网上有一堆教程讲idea如何new module或new project一步一步来创建scala工程,在这里我不推荐这个。原因是现在主流的开发环境,大多数是采用maven来构建项目的,所以建议大家用maven+plugin的方式来构建scala应用,另外,就象VB.NET/C#/F#可同时在一个项目中使用,最大限度发挥各语种特长一样,java与可以与scala在一个项目中混合使用。见下面的pom.xml示例:

  1. 复制代码

    
    
        4.0.0
        WordCount2
        WordCount2
        1.0-SNAPSHOT
        
            
                org.scala-lang
                scala-library
                2.10.4
            
            
                org.scala-lang
                scala-compiler
                2.10.4
            
            
                org.scala-lang
                scala-reflect
                2.10.4
            
            
                log4j
                log4j
                1.2.12
            
            
                org.apache.spark
                spark-core_2.10
                1.5.2
            
        
        
            
                
                    org.scala-tools
                    maven-scala-plugin
                    2.15.2
                    
                        
                            
                                compile
                                testCompile
                            
                        
                    
                
            
        
    

    复制代码

最下面的plugin是用来编译scala源代码的,毕竟java与scala是二种不同的语言,有各自的sdk和编译器,所以需要专门的maven插件来处理scala的编译。
项目的目录结构,大体跟maven的默认约定一样,只是src下多了一个scala目录,如下图:

scala和maven整合_第1张图片

这样,java源代码放在/src/java下,scala源代码放在/src/scala下,管理起来也比较清爽,上图中scala下的Hello.scala源代码如下:

1

2

3

4

5

6

7

package yjmyzz

 

class Hello {

  def sayHello(x: String): Unit = {

    println("hello," + x);

  }

}

 然后java下的HelloWorld.java里就可以调用scala的Hello类:

1

2

3

4

5

6

7

8

9

package yjmyzz;

 

public class HelloWorld {

 

    public static void main(String[] args){

        Hello h = new Hello();

        h.sayHello("scala");

    }

}

2.scala项目maven的编译打包

如果直接运行mvn clean package ,会杯具的发现

[ERROR] /Users/jimmy/Work/IdeaProjects/Default/MyScala/src/main/java/yjmyzz/HelloWorld.java:[7,9] cannot find symbol
[ERROR] symbol:   class Hello
[ERROR] location: class yjmyzz.HelloWorld

原因是mvn clean package默认只处理java源代码的编译、打包,而不管scala,所以编译时遇到Hello这个由scala语言编写的class,此时scala还没编译生成class,所以找不到相应的调用入口。

解决办法:

mvn clean scala:compile compile package

如上,在compile前加入scala:compile,这是maven-scala-plugin插件提供的选项,表示编译scala,这样一来,先编译scala,再编译java,最后打包,妥妥滴!

你可能感兴趣的:(Scala)