Scala
一、概述
Scala是一门多范式的编程语言,一种类似java的编程语言 [1] ,设计初衷是实现可伸缩的语言 [2] 、并集成面向对象编程和函数式编程的各种特性。
为什么要学习scala编程语言?
-
大数据开发工程师参与大数据领域中的多项开源项目都是scala编写,如:kafka、spark、flink等
-
下一代,可以替换JAVA编程语言
-
很多一线互联网公司,正在使用scala语言编写大数据处理应用
二、变量和类型
常用类型
Scala中也有7种数值类型:Byte、Short、Int、Long、Double、Float、Char,以及1个Boolean类型。这些类型都是类,归属于scala.*
包。还有一种常用类型为java.lang.String
用以声明字符串
表达式
表达式是可计算的语句。如:
1 + 1
你可以使用println
来输出表达式的结果。
// println 打印表达式的值 换行
// print 打印表达式的值 不换行
// 引用表达式的值打印
println(1) // 1
println(1 + 1) // 2
println("Hello!") // Hello!
println("Hello," + " world!") // Hello, world!
声明变量
除了可以重新赋值,变量和常量类似。你可以使用var
关键字来定义一个变量。
var x = 1 + 1
x = 3
println(x * x) // 9
注意:scala类型可以被推断,或者你也可以显示地声明类型,语法
var x : Int = 10
声明常量(推荐)
你可以使用val
关键字来给表达式的结果命名。
val x = 1 + 1
println(x) // 2
x = 3 //
类型转换
值类型可以按照下面的方向进行转换:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-x6Zvaegx-1680403674219)(null)]
例如:
val x: Long = 987654321
val y: Float = x // 9.8765434E8 (note that some precision is lost in this case)
val face: Char = '☺'
val number: Int = face // 9786
转换是单向,下面这样写将不会通过编译。
val x: Long = 987654321
val y: Float = x // 9.8765434E8
val z: Long = y // Does not conform
你可以将一个类型转换为子类型
运算符
-
算术运算符:
+、-、*、/、%
-
关系运算符:
==、!=、>、<、>=、<=
-
逻辑运算符:
&&、||、!
-
位运算符:
&(按位与)、|(按位或)、^(异或)、~(取反)、<<、>>、>>>(无符号)
2 二进制 00000010 3 二进制 00000011 2&3=2 00000010 & 同时为1 结果为1 不同为0 2|3=3 00000011 | 有一个为1 结果为1 不同为0 2^3=1 00000001 ^ 相同为0,不同为1 ~2=-3 11111101 2<<1=4 00000100 二进制 向左移动 n位 2>>1=1 >>>
-
赋值运算符:
=
注意:在Scala中,运算符即是方法。
10 + 1
可以写成10.+(1)
Scala类型层次结构
在Scala中,所有的值都有类型,包括数值和函数。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Up7Hfmnz-1680403670066)(null)]
Any
是所有类型的超类型,也称为顶级类型。它定义了一些通用的方法如equals
、hashCode
和toString
。Any
有两个直接子类:AnyVal
和AnyRef
。AnyVal
代表值类型。有9个预定义的非空的值类型分别是:Double
、Float
、Long
、Int
、Short
、Byte
、Char
、Unit
和Boolean
。Unit
(类似于java中的void
)是不带任何意义的值类型,它仅有一个实例可以像这样声明:()
。所有的函数必须有返回,所以说有时候Unit
也是有用的返回类型。AnyRef
代表引用类型。所有非值类型都被定义为引用类型。在Scala中,每个用户自定义的类型都是AnyRef
的子类型。如果Scala被应用在Java的运行环境中,AnyRef
相当于java.lang.Object
。Nothing
是所有类型的子类型,也称为底部类型。没有一个值是Nothing
类型的。它的用途之一是给出非正常终止的信号,如抛出异常、程序退出或者一个无限循环(可以理解为它是一个不对值进行定义的表达式的类型,或者是一个不能正常返回的方法)。Null
是所有引用类型的子类型(即AnyRef
的任意子类型)。它有一个单例值由关键字null
所定义。Null
主要是使得Scala满足和其他JVM语言的互操作性,但是几乎不应该在Scala代码中使用。我们将在后面的章节中介绍null
的替代方案。
这里有一个例子,说明了字符串、整型、布尔值和函数都是对象,这一点和其他对象一样:
val list: List[Any] = List(
"a string",
732, // an integer
'c', // a character
true, // a boolean value
() => "an anonymous function returning a string"
)
list.foreach(element => println(element))
这里定义了一个类型List<Any>
的变量list
。这个列表里由多种类型进行初始化,但是它们都是scala.Any
的实例,所以可以把它们加入到列表中。
下面是程序的输出:
a string
732
c
true
<function>
这里定义了一个类型`List<Any>`的变量`list`。这个列表里由多种类型进行初始化,但是它们都是`scala.Any`的实例,所以可以把它们加入到列表中。
下面是程序的输出:
```scala
a string
732
c
true
<function>