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

大數據生態圈中風頭正旺的Spark項目徹底是採用Scala語言開發的,不懂Scala的話,基本上就無法玩下去了。Scala與Java編譯後的class都可以運行於JVM之上,就好象.NET中F#與C#的關係。下面進入正題:html

一、下載scala sdkjava

http://www.scala-lang.org/download/ 直接到這裏下載sdk,目前最新的穩定版爲2.11.7,下載後解壓就行apache

(後面在intellij idea中建立.scala後綴源代碼時,ide會智能感知並提示你設置scala sdk,按提示指定sdk目錄爲解壓目錄便可)maven

 

二、下載scala for intellij idea的插件ide

如上圖,直接在plugins裏搜索Scala,而後安裝便可,若是不具有上網環境,或網速不給力。也能夠直接到http://plugins.jetbrains.com/plugin/?idea&id=1347手動下載插件的zip包,手動下載時,要特別注意版本號,必定要跟本機的intellij idea的版本號匹配,不然下載後沒法安裝。下載完成後,在上圖中,點擊「Install plugin from disk...」,選擇插件包的zip便可。post

 

三、如何跟maven整合大數據

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

 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>
View Code

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

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

package yjmyzz

class Hello {
  def sayHello(x: String): Unit = {
    println("hello," + x);
  }
}

 而後java下的HelloWorld.java裏就能夠調用scala的Hello類:

package yjmyzz;

public class HelloWorld {

    public static void main(String[] args){
        Hello h = new Hello();
        h.sayHello("scala");
    }
}

 

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

 

最後:gradle環境下,可參考個人另外一篇文章gradle項目中如何同時支持java與scala混合使用?

相關文章
相關標籤/搜索