Scala简述

统计世界top100大学计算机系年级前三名,从初中开始编程,学过20多种语言,最后认为Scala最难。好了,我们开始享受这个过程把:)。

二  Scala安装与配置

2.1  安装

Scala需要Java运行时库,安装Scala需要首先安装JVM虚拟机,推荐安装JDK1.8。

http://www.scala-lang.org/ 下载Scala2.11.8程序安装包

1.大数据技术之Scala_一章到三章

根据不同的操作系统选择不同的安装包,下载完成后,将安装包解压到安装目录。将scala安装目录下的bin目录加入到PATH环境变量:

SCALA_HOME:

SCALA_HOME= D:\scala-2.11.8

PATH:

在PATH变量中添加:%SCALA_HOME%\bin

完成以上流程后,在命令行输入:scala,进入如下界面:

1.大数据技术之Scala_一章到三章

 

注意:该操作Windows和Linux配置流程是一样的。可以参考Java的JDK的配置过程。

到此为止,Scala的安装已经成功。

2.2  配置IDEA

1) 打开IDEA工具,如图:点击Configure

1.大数据技术之Scala_一章到三章

 

2) 点击Plugins

1.大数据技术之Scala_一章到三章

 

3) 点击Install plugin from disk

1.大数据技术之Scala_一章到三章

 

4) 选择scala的plugins

1.大数据技术之Scala_一章到三章

5) 此时会显示一个Scala的条目,在右侧点击Restart IntelliJ IDEA

1.大数据技术之Scala_一章到三章

6) 创建Maven项目

创建的maven项目默认是不支持scala的,需要为项目添加scala的framework,如图:

1.大数据技术之Scala_一章到三章

 

在这里选择Scala后,在右边的Use library中配置你的安装目录即可,最后点击OK。

1.大数据技术之Scala_一章到三章

7) 在项目的目录结构中,创建scala文件夹,并标记为source

1.大数据技术之Scala_一章到三章

1.大数据技术之Scala_一章到三章

 

 

8) 以上配置都完成后,就可以在scala上点击右键创建scala class了

1.大数据技术之Scala_一章到三章

三  Scala基础

3.1  Hello Scala

3.1.1  IDEA运行HelloScala程序

1) 在scala上右键,创建scala object

 

2) 编写代码如下:

object HelloScala {

  def main(args: Array[String]): Unit = {

    println("Hello Scala")

  }

}

右键Run HelloScala

3.1.2  控制台运行HelloScala程序

1) 打包

scala程序的打包过程和java工程的打包是一样的,因为我们都是使用maven构建的项目,所以你只需要一Java的Maven工程一致的打包方式打包项目即可。即:使用idea,右侧的maven工具,双击package即可,该步骤完成后会在项目的目录结构中生成一个target文件夹,其中有打包好的jar文件如图:

1.大数据技术之Scala_一章到三章

打包好的jar文件:

1.大数据技术之Scala_一章到三章

2) 运行

将该jar包复制到任意位置,然后打开cmd,执行命令:

scala -cp C:\Users\61661\Desktop\scala-1.0-SNAPSHOT.jar HelloScala

即可看到效果如图:

1.大数据技术之Scala_一章到三章

3.2  声明值和变量

Scala声明变量有两种方式,一个用val,一个用var。

val / var 变量名 : 变量类型 = 变量值。

val定义的值是不可变的,它不是一个常量,是不可变量,或称之为只读变量

val示例:

scala> val a1 = 10

scala> a1 = 20(此处会报错,因为val不允许初始化后再次修改a1变量的引用)

var示例:

scala> var a2 = 10

scala> a2 = 20

尖叫提示:

1、scala默认为匿名变量分配val

2、val定义的变量虽然不能改变其引用的内存地址,但是可以改变其引用的对象的内部的其他属性值。

3为了减少可变性引起的bug,应该尽可能地使用不可变变量。变量类型可以省略,解析器会根据值进行推断。val和var声明变量时都必须初始化。

3.3  常用类型

3.3.1  常用类型介绍(1字节(byte)=8位(bit))

Scala有8种数据类型:Byte、Char、Short、Int、Long、Float、Double以及Boolean。

Boolean

true 或者 false

Byte

8位, 有符号

Short

16位, 有符号

Int

32位, 有符号

Long

64位, 有符号

Char

16位, 无符号

Float

32位, 单精度浮点数

Double

64位, 双精度浮点数

String

其实就是由Char数组组成

与Java中的数据类型不同,Scala并不区分基本类型和引用类型,所以这些类型都是对象,可以调用相对应的方法。String直接使用的是java.lang.String. 不过,由于String实际是一系列Char的不可变的集合,Scala中大部分针对集合的操作,都可以用于String,具体来说,String的这些方法存在于类scala.collection.immutable.StringOps中。

由于String在需要时能隐式转换为StringOps,因此不需要任何额外的转换,String就可以使用这些方法。

每一种数据类型都有对应的Rich* 类型,如RichInt、RichChar等,为基本类型提供了更多的有用操作。

3.3.2  常用类型结构图

Scala中,所有的值都是类对象,而所有的类,包括值类型,都最终继承自一个统一的根类型Any。统一类型,是Scala的又一大特点。更特别的是,Scala中还定义了几个底层类(Bottom Class),比如Null和Nothing。

  1. Null是所有引用类型的子类型,而Nothing是所有类型的子类型。Null类只有一个实例对象,null,类似于Java中的null引用。null可以赋值给任意引用类型,但是不能赋值给值类型。
  2. Nothing,可以作为没有正常返回值的方法的返回类型,非常直观的告诉你这个方法不会正常返回,而且由于Nothing是其他任意类型的子类,他还能跟要求返回值的方法兼容。
  3. Unit类型用来标识过程,也就是没有明确返回值的函数。 由此可见,Unit类似于Java里的void。Unit只有一个实例,(),这个实例也没有实质的意义。

1.大数据技术之Scala_一章到三章

3.4  算数操作符重载

+-*/%可以完成和Java中相同的工作,但是有一点区别,他们都是方法。你几乎可以用任何符号来为方法命名。

举例:

scala> 1 + 2

等同于:

scala> 1.+(2)

尖叫提示:Scala中没有++、--操作符,需要通过+=、-=来实现同样的效果。

3.5  调用函数与方法

在scala中,一般情况下我们不会刻意的去区分函数与方法的区别,但是他们确实是不同的东西。后面我们再详细探讨。首先我们要学会使用scala来调用函数与方法。

1) 调用函数,求方根

scala> import scala.math._

scala> sqrt(100)

2) 调用方法,静态方法(scala中没有静态方法这个概念,需要通过伴生类对象来实现)

scala> BigInt.probablePrime(16, scala.util.Random)

3) 调用方法,非静态方法,使用对象调用

scala> "HelloWorld".distinct

4) apply与update方法

apply方法是调用时可以省略方法名的方法。用于构造和获取元素:

"Hello"(4)  等同于  "Hello".apply(4)

Array(1,2,3) 等同于 Array.apply(1,2,3)

如:

println("Hello"(4))

println("Hello".apply(4))

在StringOps中你会发现一个 def apply(n: Int): Char方法定义。update方法也是调用时可以省略方法名的方法,用于元素的更新:

arr(4) = 5  等同于  arr.update(4,5)

如:

val arr1 = new Array[Int](5)

arr1(1) = 2

arr1.update(1, 2)

println(arr1.mkString(","))

3.6 option类型

Scala为单个值提供了对象的包装器,表示为那种可能存在也可能不存在的值。他只有两个有效的子类对象,一个是Some,表示某个值,另外一个是None,表示为空,通过Option的使用,避免了使用null、空字符串等方式来表示缺少某个值的做法。

如:

val map1 = Map("Alice" -> 20, "Bob" -> 30)

println(map1.get("Alice"))

println(map1.get("Jone"))

相关文章:

  • 2021-07-22
  • 2021-04-12
  • 2021-12-22
  • 2021-05-20
  • 2021-08-24
  • 2021-10-12
  • 2021-12-13
猜你喜欢
  • 2021-04-05
  • 2021-05-26
  • 2021-07-03
  • 2021-10-20
  • 2022-01-02
  • 2022-01-22
  • 2021-09-01
相关资源
相似解决方案