scala + intellij idea 环境搭建及编译、打包
2018-03-10 16:23
507 查看
大数据生态圈中风头正旺的Spark项目完全是采用Scala语言开发的,不懂Scala的话,基本上就没法玩下去了。Scala与Java编译后的class均可以运行于JVM之上,就好象.NET中F#与C#的关系。下面进入正题:1、下载scala sdkhttp://www.scala-lang.org/download/ 直接到这里下载sdk,目前最新的稳定版为2.11.7,下载后解压就行(后面在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示例:
View Code最下面的plugin是用来编译scala源代码的,毕竟java与scala是二种不同的语言,有各自的sdk和编译器,所以需要专门的maven插件来处理scala的编译。
项目的目录结构,大体跟maven的默认约定一样,只是src下多了一个scala目录,如下图:
这样,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,最后打包,妥妥滴!
如上图,直接在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示例:
View Code最下面的plugin是用来编译scala源代码的,毕竟java与scala是二种不同的语言,有各自的sdk和编译器,所以需要专门的maven插件来处理scala的编译。
项目的目录结构,大体跟maven的默认约定一样,只是src下多了一个scala目录,如下图:
这样,java源代码放在/src/java下,scala源代码放在/src/scala下,管理起来也比较清爽,上图中scala下的Hello.scala源代码如下:
[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,最后打包,妥妥滴!
相关文章推荐
- scala + intellij idea 环境搭建及编译、打包
- scala + intellij idea 环境搭建及编译、打包
- scala + intellij idea 环境搭建及编译、打包
- scala + intellij idea 环境搭建及编译、打包
- Intellij IDEA开发环境搭建,scala配置及打包,jar包在spark中的运行
- IntelliJ IDEA13.1.3+Scala2.11.1环境搭建
- Spark学习: Spark-Scala-IntelliJ开发环境搭建和编译Jar包流程
- 0070 IntelliJ IDEA+Scala+Hadoop +Spark的开发环境搭建
- Spark-Scala-IntelliJ开发环境搭建和编译Jar包流程
- Spark Scala IntelliJ IDEA开发环境搭建(入门)
- Intellij IDEA使用Maven搭建spark开发环境(scala)
- scala + intellij idea 环境搭建及编译、打包
- scala + intellij idea 环境搭建及编译、打包
- scala + intellij idea 环境搭建及编译、打包
- IntelliJ IDEA13.1.3+Scala2.11.1环境搭建
- scala + intellij idea 环境搭建及编译、打包
- Scala + Intellij IDEA 环境搭建及编译、打包
- Idea开发环境中搭建Maven并且使用Maven打包部署程序
- Intellij Idea搭建Spark开发环境
- Maven项目管理(一) IntelliJ Idea+Maven环境搭建与基于命令行的基本使用