大数据生态圈中风头正旺的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>
最下面的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混合使用?