阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Scala + Intellij IDEA 环境搭建及编译、打包

154次阅读
没有评论

共计 3807 个字符,预计需要花费 10 分钟才能阅读完成。

大数据生态圈中风头正旺的 Spark 项目完全是采用 Scala 语言开发的,不懂 Scala 的话,基本上就没法玩下去了。Scala 与 Java 编译后的 class 均可以运行于 JVM 之上,就好象.NET 中 F#与 C# 的关系。下面进入正题:

1、下载 scala sdk

http://www.scala-lang.org/download/ 直接到这里下载 sdk,目前最新的稳定版为 2.11.7,下载后解压就行

(后面在 intellij idea 中创建.scala 后缀源代码时,ide 会智能感知并提示你设置 scala sdk,按提示指定 sdk 目录为解压目录即可)

2、下载 scala for intellij idea 的插件

Scala + 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 示例:

Scala + Intellij IDEA 环境搭建及编译、打包

 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 目录,如下图:

Scala + Intellij IDEA 环境搭建及编译、打包

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

最后:gradle 环境下,可参考我的另一篇文章 Gradle 项目中如何同时支持 Java 与 Scala 混合使用?

使用 IntelliJ IDEA 13 搭建 Android 集成开发环境图文教程 http://www.linuxidc.com/Linux/2015-09/123416.htm

IntelliJ IDEA 12 创建 Web 项目图文详细教程 http://www.linuxidc.com/Linux/2013-05/84213.htm

用 IntelliJ IDEA 开发 Android 程序图文教程 http://www.linuxidc.com/Linux/2013-03/81471.htm

IntelliJ IDEA 12 开发 haXe NME 应用配置指南 http://www.linuxidc.com/Linux/2013-01/77227.htm

IntelliJ IDEA 运行 Play Framework 的 test mode http://www.linuxidc.com/Linux/2013-07/87694.htm

Ubuntu 13.04 安装 IntelliJ IDEA 12 http://www.linuxidc.com/Linux/2013-11/93014.htm

IntelliJ IDEA 12 创建 Maven 管理的 Java Web 项目(图解) http://www.linuxidc.com/Linux/2014-04/99687p2.htm

IntelliJ IDEA 常用快捷键列表及技巧大全  http://www.linuxidc.com/Linux/2015-04/116398.htm 

IntelliJ IDEA 的详细介绍:请点这里
IntelliJ IDEA 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-08/134135.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计3807字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中