vlambda博客
学习文章列表

一、Scala简介与环境搭建

1.1 概述

Scala(斯嘎拉)这个名字来源于"Scalable Language(可伸缩的语言)", 它是一门基于JVM的多范式编程语言, 通俗的说: Scala是一种运行在JVM上的函数式的面向对象语言. 之所以这样命名, 是因为它的设计目标是: 随着用户的需求一起成长. Scala可被广泛应用于各种编程任务, 从编写小型的脚本到构建巨型系统, 它都能胜任. 正因如此, Scala得以提供一些出众的特性, 例如: 它集成了面向对象编程和面向函数式编程的各种特性, 以及更高层的并发模型.

总而言之, Scala融汇了许多前所未有的特性, 而同时又运行于JVM之上, 随着开发者对Scala的兴趣日增, 以及越来越多的工具支持, 无疑Scala语言将成为你手上一门必不可少的工具.

 基于JVM解释:Scala的运行环境和Java类似, 也是依赖JVM的.

 多范式解释: Scala支持多种编程风格

1.2 Scala之父

 Scala之父是: Martin·Odersky(马丁·奥德斯基), 他是EPFL(瑞士领先的技术大学)编程研究组的教授. 也是Typesafe公司(现已更名为: Lightbend公司)的联合创始人. 他在整个职业生涯中一直不断追求着一个目标:让写程序这样一个基础工作变得高效、简单、且令人愉悦. 他曾经就职于IBM研究院、耶鲁大学、卡尔斯鲁厄大学以及南澳大利亚大学. 在此之前,他在瑞士苏黎世联邦理工学院追随Pascal语言创始人Niklaus Wirth(1984年图灵奖获得者)学习,并于1989年获得博士学位.
联邦理工学院的马丁·奥德斯基(Martin Odersky)于2001年开始设计Scala。

马丁·奥德斯基是编译器及编程的狂热爱好者,长时间的编程之后,希望发明一种语言,能够让写程序这样的基础工作变得高效,简单。所以当接触到JAVA语言后,对JAVA这门便携式,运行在网络,且存在垃圾回收的语言产生了极大的兴趣,所以决定将函数式编程语言的特点融合到JAVA中,由此发明了两种语言(Pizza & Scala)。
Pizza和Scala极大地推动了Java编程语言的发展。

  1. JDK5.0 的泛型、增强for循环、自动类型转换等,都是从Pizza引入的新特性。JDK8.0
    的类型推断、Lambda表达式就是从Scala引入的特性。

  2. JDK5.0和JDK8.0的编辑器就是马丁·奥德斯基写的,因此马丁·奥德斯基一个人的 战斗力抵得上一个Java开发团队。

1.3 语言特点

  • Scala是兼容的

    兼容Java,可以访问庞大的Java类库,例如:操作mysql、redis、freemarker、activemq等等

  • Scala是精简的

    Scala表达能力强,一行代码抵得上多行Java代码,开发速度快

  • Scala是高级的

    Scala可以让你的程序保持短小, 清晰, 看起来更简洁, 更优雅

  • Scala是静态类型的

    Scala拥有非常先进的静态类型系统, 支持: 类型推断和模式匹配等

  • Scala可以开发大数据应用程序

    例如: Spark程序、Flink程序等等...

2. Scala程序和Java程序对比

2.1 程序的执行流程对比

Java程序编译执行流程

Scala程序编译执行流程

一、Scala简介与环境搭建

2.2 代码对比

**需求: **

定义一个学生类, 属性为: 姓名和年龄, 然后在测试类中创建对象并测试.

Java代码

//定义学生类
public class Student{
private String name; //姓名
private int age; //年龄

//空参和全参构造
public Student(){}

public Student(String name, int age){
this.name = name;
this.age = age;
}

//getXxx()和setXxx()方法
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}

//测试类
public class StudentDemo {
public static void main(String[] args) {
Student s1 = new Student("张三", 23); //创建Student类型的对象s1, 并赋值
System.out.println(s1); //打印对象, 查看结果.
}
}

Scala代码

case class Student(var name:String, var age:Int)		//定义一个Student类
val s1 = Student("张三", 23) //创建Student类型的对象s1, 并赋值
println(s1) //打印对象, 查看结果.

3. Scala环境搭建

3.1 概述

scala程序运行需要依赖于Java类库,那么必须要有Java运行环境,scala才能正确执行. 所以要编译运行scala程序,需要:

  • JDK(JDK包含JVM)

  • Scala编译器(Scala SDK)

接下来,需要依次安装以下内容:

  • 安装JDK

  • 安装Scala SDK

  • 在IDEA中安装Scala插件

3.2 安装JDK

安装JDK 1.8 64位版本,并配置好环境变量, 此过程略.

3.3 安装Scala SDK

Scala SDK是scala语言的编译器,要开发scala程序,必须要先安装Scala SDK

本次安装的版本是: 2.11.12

步骤

  1. 下载Scala SDK.

  2. 安装Scala SDK.

    2.1 双击scala-2.11.12.msi,将scala安装在指定目录, 傻瓜式安装, 下一步下一步即可.
    2.2 安装路径要合法, 不要出现中文, 空格等特殊符号.

  3. 测试是否安装成功

    打开控制台,输入: scala -version

3.4 安装IDEA scala插件

IDEA默认是不支持scala程序开发的,所以需要在IDEA中安装scala插件, 让它来支持scala语言。

步骤

3.4.1 下载指定版本IDEA scala插件.

 1. 下载的Scala插件必须和你安装的IDEA版本一致

3.4.2 IDEA配置scala插件
  1. 选择配置 > 选择插件

一、Scala简介与环境搭建

  1. 点击小齿轮 > 选择从本地安装插件

    一、Scala简介与环境搭建

  2. 找到下载的插件位置,点击OK

    一、Scala简介与环境搭建

3.4.3 重新启动IDEA

一、Scala简介与环境搭建

4. Scala解释器

4.1 概述

后续我们会使用scala解释器来学习scala基本语法,scala解释器像Linux命令一样,执行一条代码,马上就可以让我们看到执行结果,用来测试比较方便。

我们接下来学习:

  • 启动scala解释器

  • 在scala解释器中执行scala代码

  • 退出scala解释器

4.2 启动scala解释器

要启动scala解释器,只需要以下几步:

  • 按住windows键 + r

  • 输入scala即可

一、Scala简介与环境搭建

4.3 执行scala代码

在scala的命令提示窗口中输入println("hello, world"),回车执行.

一、Scala简介与环境搭建

4.4 退出解释器

方式一: 点击右上角的"×"

方式二: 输入:quit退出 

5. 案例: 做最好的自己.

5.1 需求

提示用户录入他/她最想对自己说的一句话, 然后将这句话打印到控制台上.

5.2 目的

测试Scala和Java之间可以无缝互调(即: Scala兼容Java,可以访问庞大的Java类库).

5.3 思路分析

1. 因为涉及到键盘录入了, 所以先导包.
2. 提示用户录入他/她最想对自己说的一句话.
3. 接收用户录入的内容, 并打印.

5.4 参考代码

//1. 导入Java中的Scanner类. 引入Java类库
import java.util.Scanner
//2. 提示用户录入他/她最想对自己说的一句话. Scala代码
println("请录入一句您最想对自己说的一句话: ")
//3. 打印用户录入的内容. Scala代码 + Java类库
//不忘初心, 方得始终, 做最好的自己!
println("我最想对自己说: " + new Scanner(System.in).nextLine())