---------------------
前言
---------------------
项目关系,希望用Spark GraphX做数据分析及图像展示,但前提是得回spark;spark是基于scala的,scala是基于JAVA的……所以,要想用Spark GraphX,技术堆栈大体上应该是这样的:Java -> Scala -> Spark -> Spark GraphX。
 
JAVA都这么多年了……就不说了,我们从学习Scala开始。
 
 
--------------------
前提
--------------------
1)Java配置完成,版本在1.8以上;
因为Scala是基于Java开发的,编译之后生成的class文件也可以远行在JVM上,并被Java调用。
2)IntelliJ IDEA已安装完成(我的版本是:2017.2.2)。
 
 
--------------------
安装Scala
--------------------
1. 安装Scala插件
依次:IntelliJ IDEA -> Preferences -> Plugins -> Browse repositories...
 
1)在搜索框输入scala
2)在列表中选择Scala
3)点击右侧框的“Install”按钮(下图是安装完成之后的样子)
 
 
2. 安装Scala SDK
网上说的是先到http://www.scala-lang.org/download/ 下载压缩包,在本地解压,IDEA就可以自动识别了。(详细参考:https://www.cnblogs.com/yjmyzz/p/4694219.html
 
而我用的是另一个方法(有点儿笨,有点儿捉急了……):
1)在没有安装SDK的情况下,直接先创建了一个Scala项目(创建项目的步骤下面有说明),
2)打开Hello.scala文件的时候,IDEA会在编辑器的右上角提示:Setup Scala SDK
点击链接,在弹出框中,根据提示:
-> download SDK(等待时间比较久……)
-> 选择版本(我的是2.12.4)
-> STB最后自动更新一些jar包(又是一段时间的等待……)
 
在安装过程中,右下角的EventLog栏里会有STB的提示,建议选择“Auto-Import”。
 
 
--------------------
创建项目、运行 — 经典的HelloWorld
--------------------
1. 创建项目
1)Create New Project(或:File -> New -> Project);
2)在左侧框选择“Scala” -> 在右侧框再次选择“Scala”,没有Scala则选择SBT,点击下一步;
3)在Name里输入:HelloWorld
在Location里选择自己想要存工程的路径,点击finish
 
创建出来的Scala项目的路径结构大概是这个样子的:
 
目录scala是我们下代码的地方
目录test是些单元测试的代码的地方(后面会有详细说明)
貌似还应该有个跟scala并列的java目录,但是在我的项目里没有……
 
 
2. 写代码
在工程目录src/main/scala上,右键单击,选择:New -> Scala Script
(我第一次创建文件的时候并没有安装Scala SDK,所以没有这个文件类型,只好选择File……)
输入文件名:Hello.scala
 
输入代码:
object HelloWorld {
def main(args: Array[String]): Unit = {
println("Hello, world!")
}
}
 
3. 运行配置
在Edit Configurations...里添加一项SBT:
 
在SBT Task下新增一项,输入:
Name:run scala helloworld
Tasks: ~run ('~'符号,用来触发SBT编译并运行项目)
保存退出。
 
点击“运行”按钮,在控制台输入运行结果:
 
[info] Loading settings from plugins.sbt ...
[info] Loading project definition from /Users/yp-tc-m-2755/Documents/devopement/scala/hellowold/project
[info] Loading settings from build.sbt ...
[info] Set current project to hellowold (in build file:/Users/yp-tc-m-2755/Documents/devopement/scala/hellowold/)
[info] Updating ...
[info] Done updating.
[info] Compiling 1 Scala source to /Users/yp-tc-m-2755/Documents/devopement/scala/hellowold/target/scala-2.12/classes ...
[info] Non-compiled module 'compiler-bridge_2.12' for Scala 2.12.4. Compiling...
[info] Compilation completed in 12.446s.
[info] Done compiling.
[info] Packaging /Users/yp-tc-m-2755/Documents/devopement/scala/hellowold/target/scala-2.12/hellowold_2.12-0.1.jar ...
[info] Done packaging.
[info] Running HelloWorld
Hello, world!
[success] Total time: 22 s, completed 2018-2-6 18:55:20
 
 
--------------------
遗留问题
--------------------
在build.sbt里的所有关键字都是红的,提示:Cannot resolve symbol
虽然不影响运行,但是这样就不能在这里添加依赖了。比如,单元测试的依赖:
libraryDependencies += "org.scalatest" %% "scalatest" % "3.0.1" % "test"
 
https://stackoverflow.com上面找到一些方法,但是对我都不起作用,求大神指教。
 
 
 
 
--------------------
参考
--------------------
1)在线教程:
2)scala intellij idea 环境搭建及编译:
3)GETTING STARTED WITH SCALA IN INTELLIJ
4)Installing, Updating and Uninstalling Repository Plugins
5)TESTING SCALA IN INTELLIJ WITH SCALATEST
 
 
 
 
 
 
 

Scala & IntelliJ IDEA:环境搭建、helloworld的更多相关文章

  1. Scala & IntelliJ IDEA环境搭建升级版:在JAVA中调用Scala的helloworld

    --------------------- 前言 --------------------- 项目关系,希望用Spark GraphX做数据分析及图像展示,但前提是得会spark:spark是基于sc ...

  2. scala + intellij idea 环境搭建及编译、打包

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

  3. scala 入门Eclipse环境搭建及第一个入门经典程序HelloWorld

    scala 入门Eclipse环境搭建及第一个入门经典程序HelloWorld 学习了: http://blog.csdn.net/wangmuming/article/details/3407911 ...

  4. scala 入门Eclipse环境搭建

    scala 入门Eclipse环境搭建及第一个入门经典程序HelloWorld IDE选择并下载: scala for eclipse 下载: http://scala-ide.org/downloa ...

  5. Scala进阶之路-为什么要学习Scala以及开发环境搭建

    Scala进阶之路-为什么要学习Scala以及开发环境搭建 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 最近人工智能和大数据那是相当的火呀,人工智能带动了Python的流行,区块 ...

  6. Cordova环境搭建 & HelloWorld

    目前的手机APP有三类:原生APP,WebAPP,HybridApp:HybridApp结合了前两类APP各自的优点,越来越流行. Cordova就是一个中间件,让我们把WebAPP打包成Hybrid ...

  7. jni 入门 android的C编程之旅 --->环境搭建&&helloworld

    需要进行jni的开发有一下几个条件: 1:能初步使用C/C++如果不会,请参读 谭浩强的  C编程语言 2:android应用开发已经基本入门,如果没有,请先行学习 这两个条件基本满足后,我们开始了: ...

  8. Windows下Eclipse+Scala+Spark开发环境搭建

    1.安装JDK及配置java环境变量 本文使用版本为jdk1.7.0_79,过程略 2.安装scala 本文使用版本为2.11.8,过程略 3.安装spark 本文使用版本为spark-2.0.1-b ...

  9. scala+hadoop+spark环境搭建

    一.JDK环境构建 在指定用户的根目录下编辑.bashrc文件,添加如下部分: # .bashrc # Source global definitions if [ -f /etc/bashrc ]; ...

  10. IntelliJ Idea 环境搭建

    安装IntelliJ Idea 可以去官网下载: https://www.jetbrains.com/idea/download/#section=windows 选择Ultimate.一路下一步安装 ...

随机推荐

  1. 嵌入式Linux学习笔记 NAND Flash控制器

    一.NAND Flash介绍和NAND Flash控制器的使用 NAND Flash在嵌入式系统中的作用,相当于PC上的硬盘 常见的Flash有NOR Flash和NAND Flash,NOR Fla ...

  2. BUFSIZ

    转http://www.judymax.com/archives/262 今天在看示例程序时冒出来一句args = emalloc(BUFSIZ); BUFSIZ是什么意思,查了一下才明白. 这是st ...

  3. 【BZOJ 4556】字符串

    [链接]h在这里写链接 [题意]     给你一个长度为n(n<=10^5)的字符串以及一个整数m(m<=10^5),代表询问的次数.     每个询问由4个整数a,b,c,d给出    ...

  4. Java反射学习总结二(用反射调用对象的私有属性和方法)

    大家都知道正常的调用是不可以访问对象的private修饰的属性和方法的,这也是Java的封装性原则. 但是有没有方法可以强制去访问对象的private修饰的属性和方法呢?那就是用反射!(这个可能在面试 ...

  5. vue项目中一些文件的作用

    原文 简书原文:https://www.jianshu.com/p/38749e5bec3c 大纲 1.vue项目结构 2.主要的配置文件 2.1.package.json 2.2.dev-serve ...

  6. 9、getopt的用法,被用来解析命令行选项参数

    #include <unistd.h>       extern char *optarg;  //选项的参数指针       extern int optind,   //下一次调用ge ...

  7. 简要分析武汉一起好P2P平台的核心功能

    写作背景 加入武汉一起好,正式工作40天了,对公司的核心业务有了更多的了解,想梳理下自己对于P2P平台的认识. 武汉一起好,自己运营的yiqihao.com,是用PHP实现的,同时也帮助若干P2P平台 ...

  8. ios开发网络学习五:输出流以及文件上传

    一:输出流 #import "ViewController.h" @interface ViewController ()<NSURLConnectionDataDelega ...

  9. goodFeaturesToTrack——Shi-Tomasi角点检测

    J.Shi和C.Tomasi在1994年在其论文"Good Features to Track"中,提出了一种对Harris角点检测算子的改进算法--Shi-Tomasi角点检测算 ...

  10. CoreData使用方法二:NSFetchedResultsController实例操作与解说

    学习了NSFetchedResultsController.才深深的体会到coredata的牛逼之处.原来Apple公司弄个新技术.不是平白无故的去弄,会给代码执行到来非常大的优点.coredata不 ...