天天看點

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的插件

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

3、如何跟maven整合

網上有一堆教程講idea如何new module或new project一步一步來建立scala工程,在這裡我不推薦這個。原因是現在主流的開發環境,大多數是采用maven來建構項目的,是以建議大家用maven+plugin的方式來建構scala應用,另外,就象VB.NET/C#/F#可同時在一個項目中使用,最大限度發揮各語種特長一樣,java與可以與scala在一個項目中混合使用。見下面的pom.xml示例:

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

View Code

最下面的plugin是用來編譯scala源代碼的,畢竟java與scala是二種不同的語言,有各自的sdk和編譯器,是以需要專門的maven插件來處理scala的編譯。

項目的目錄結構,大體跟maven的預設約定一樣,隻是src下多了一個scala目錄,如下圖:

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

這樣,java源代碼放在/src/java下,scala源代碼放在/src/scala下,管理起來也比較清爽,上圖中scala下的Hello.scala源代碼如下:

 然後java下的HelloWorld.java裡就可以調用scala的Hello類:

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