scala和maven整合實踐


1.scala和maven如何整合

     網上有一堆教程講idea如何new module或new project一步一步來創建scala工程,在這里我不推薦這個。原因是現在主流的開發環境,大多數是采用maven來構建項目的,所以建議大家用maven+plugin的方式來構建scala應用,另外,就象VB.NET/C#/F#可同時在一個項目中使用,最大限度發揮各語種特長一樣, java與可以與scala在一個項目中混合使用 。見下面的pom.xml示例:
  1. <?xml version="1.0" encoding="UTF-8"?>
    <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>WordCount2</groupId>
        <artifactId>WordCount2</artifactId>
        <version>1.0-SNAPSHOT</version>
        <dependencies>
            <dependency>
                <groupId>org.scala-lang</groupId>
                <artifactId>scala-library</artifactId>
                <version>2.10.4</version>
            </dependency>
            <dependency>
                <groupId>org.scala-lang</groupId>
                <artifactId>scala-compiler</artifactId>
                <version>2.10.4</version>
            </dependency>
            <dependency>
                <groupId>org.scala-lang</groupId>
                <artifactId>scala-reflect</artifactId>
                <version>2.10.4</version>
            </dependency>
            <dependency>
                <groupId>log4j</groupId>
                <artifactId>log4j</artifactId>
                <version>1.2.12</version>
            </dependency>
            <dependency>
                <groupId>org.apache.spark</groupId>
                <artifactId>spark-core_2.10</artifactId>
                <version>1.5.2</version>
            </dependency>
        </dependencies>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.scala-tools</groupId>
                    <artifactId>maven-scala-plugin</artifactId>
                    <version>2.15.2</version>
                    <executions>
                        <execution>
                            <goals>
                                <goal>compile</goal>
                                <goal>testCompile</goal>
                            </goals>
                        </execution>
                    </executions>
                </plugin>
            </plugins>
        </build>
    </project>

最下面的plugin是用來編譯scala源代碼的,畢竟java與scala是二種不同的語言,有各自的sdk和編譯器,所以需要專門的maven插件來處理scala的編譯。
項目的目錄結構,大體跟maven的默認約定一樣,只是src下多了一個scala目錄,如下圖:

這樣,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,最后打包,妥妥滴!


 


免責聲明!

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



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