1. 程式人生 > >scala + intellij idea 環境搭建及編譯、打包

scala + intellij idea 環境搭建及編譯、打包

大資料生態圈中風頭正旺的Spark專案完全是採用Scala語言開發的,不懂Scala的話,基本上就沒法玩下去了。Scala與Java編譯後的class均可以運行於JVM之上,就好象.NET中F#與C#的關係。下面進入正題:

1、下載scala sdk

(後面在intellij idea中建立.scala字尾原始碼時,ide會智慧感知並提示你設定scala sdk,按提示指定sdk目錄為解壓目錄即可)

2、下載scala for intellij idea的外掛

如上圖,直接在plugins裡搜尋Scala,然後安裝即可,如果不具備上網環境,或網速不給力。也可以直接到http://plugins.jetbrains.com/plugin/?idea&id=1347

手動下載外掛的zip包,手動下載時,要特別注意版本號,一定要跟本機的intellij idea的版本號匹配,否則下載後無法安裝。下載完成後,在上圖中,點選“Install plugin from disk...”,選擇外掛包的zip即可。

3、如何跟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"?>
 2 <project xmlns="http://maven.apache.org/POM/4.0.0"
 3          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 4          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 5     <modelVersion
>4.0.0</modelVersion> 6 7 <groupId>yjmyzz</groupId> 8 <artifactId>MyScala</artifactId> 9 <version>1.0</version> 10 11 <dependencies> 12 <dependency> 13 <groupId>org.scala-lang</groupId> 14 <artifactId>scala-library</artifactId> 15 <version>2.11.7</version> 16 </dependency> 17 <dependency> 18 <groupId>org.scala-lang</groupId> 19 <artifactId>scala-compiler</artifactId> 20 <version>2.11.7</version> 21 </dependency> 22 <dependency> 23 <groupId>org.scala-lang</groupId> 24 <artifactId>scala-reflect</artifactId> 25 <version>2.11.7</version> 26 </dependency> 27 <dependency> 28 <groupId>log4j</groupId> 29 <artifactId>log4j</artifactId> 30 <version>1.2.12</version> 31 </dependency> 32 <dependency> 33 <groupId>com.google.collections</groupId> 34 <artifactId>google-collections</artifactId> 35 <version>1.0</version> 36 </dependency> 37 </dependencies> 38 39 <build> 40 <plugins> 41 <plugin> 42 <groupId>org.scala-tools</groupId> 43 <artifactId>maven-scala-plugin</artifactId> 44 <version>2.15.2</version> 45 <executions> 46 <execution> 47 <goals> 48 <goal>compile</goal> 49 <goal>testCompile</goal> 50 </goals> 51 </execution> 52 </executions> 53 </plugin> 54 </plugins> 55 </build> 56 </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"); } }

4、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,最後打包,妥妥滴!