This commit is contained in:
luoxiang 2019-05-05 22:46:46 +08:00
parent 0d7f2204c5
commit 224379533e
3 changed files with 158 additions and 0 deletions

View File

@ -140,3 +140,5 @@ TODO
## 十二、Scala
1. [Scala简介及开发环境配置](https://github.com/heibaiying/BigData-Notes/blob/master/notes/Scala简介及开发环境配置.md)
2.

View File

@ -0,0 +1,156 @@
# Scala基本数据类型
## 一、数据类型
Scala 拥有下表所示的数据类型其中Byte、Short、Int、Long和Char类型统称为整数类型整数类型加上Float和Double统称为数值类型。Scala数值类型的取值范围和Java对应类型的取值范围相同。
| 数据类型 | 描述 |
| -------- | ------------------------------------------------------------ |
| Byte | 8位有符号补码整数。数值区间为 -128 到 127 |
| Short | 16位有符号补码整数。数值区间为 -32768 到 32767 |
| Int | 32位有符号补码整数。数值区间为 -2147483648 到 2147483647 |
| Long | 64位有符号补码整数。数值区间为 -9223372036854775808 到 9223372036854775807 |
| Float | 32 位, IEEE 754 标准的单精度浮点数 |
| Double | 64 位 IEEE 754 标准的双精度浮点数 |
| Char | 16位无符号Unicode字符, 区间值为 U+0000 到 U+FFFF |
| String | 字符序列 |
| Boolean | true或false |
| Unit | 表示无值等同于Java中的void。用作不返回任何结果的方法的结果类型。Unit只有一个实例值写成()。 |
| Null | null 或空引用 |
| Nothing | Nothing类型在Scala的类层级的最低端它是任何其他类型的子类型。 |
| Any | Any是所有其他类的超类 |
| AnyRef | AnyRef类是Scala里所有引用类(reference class)的基类 |
## 二、字面量
Scala和Java字面量在使用上很多相似比如都使用F或f表示浮点型都使用L或l表示Long类型。故下文主要介绍两者差异部分。
```scala
scala> 1.2
res0: Double = 1.2
scala> 1.2f
res1: Float = 1.2
scala> 1.4F
res2: Float = 1.4
scala> 1
res3: Int = 1
scala> 1l
res4: Long = 1
scala> 1L
res5: Long = 1
```
### 2.1 整数字面量
Scala支持10进制和16进制但不支持八进制字面量和以0开头的整数字面量。
```scala
scala> 012
<console>:1: error: Decimal integer literals may not have a leading zero. (Octal syntax is obsolete.)
```
### 2.2 字符串字面量
#### 1. 字符字面量
字符字面量由一对单引号和中间的任意Unicode字符组成。你可以显式的给出原字符、也可以使用字符的Unicode码来表示还可以包含特殊的转义字符。
```scala
scala> '\u0041'
res0: Char = A
scala> 'a'
res1: Char = a
scala> '\n'
res2: Char =
```
#### 2. 字符串字面量
字符串字面量由双引号包起来的字符组成。
```scala
scala> "hello world"
res3: String = hello world
```
#### 3.原生字符串
Scala提供了`""" ... """`语法,通过三个双引号来表示原生字符串和多行字符串,使用该种方式,原生字符串中的特殊字符不会被转义。
```scala
scala> "hello \tool"
res4: String = hello ool
scala> """hello \tool"""
res5: String = hello \tool
scala> """hello
| world"""
res6: String =
hello
world
```
### 2.3 符号字面量
符号字面量写法为: `'标识符` ,这里 标识符可以是任何字母或数字的组合。符号字面量会被映射成`scala.Symbol`的实例,如:符号字面量 `'x `会被编译器翻译为`scala.Symbol("x")`。符号可选方法很少,只能通过`.name`获取其名称。
需要注意的是任意的同名symbols都指向同一个Symbol对象而不同名的symbols一定指向不同的Symbol对象。
```scala
scala> val sym = 'ID008
sym: Symbol = 'ID008
scala> sym.name
res12: String = ID008
```
### 2.4 插值表达式
Scala支持插值表达式。
```scala
scala> val name="xiaoming"
name: String = xiaoming
scala> println(s"My name is $name,I'm ${2*9}.")
My name is xiaoming,I'm 18.
```
## 三、运算符
Scala和其他语言一样支持大多数的操作运算符
- 算术运算符(+-*/%
- 关系运算符(==!=><>=<=
- 逻辑运算符(&&||!&|)
- 位运算符(~&|^<<>>>>>)
- 赋值运算符(=+=-=*=/=%=<<=>>=&=^=|=)
以上操作符的基本使用与其他语言类似,以下主要介绍差异部分和注意事项。
### 3.1 运算符即方法
Scala的面向对象比Java更加纯粹在Scala中一切都是对象。对于`1+2`,实际上是调用了Int类中名为`+`的方法所以1+2,也可以写成`1.+(2)`
```scala
scala> 1+2
res14: Int = 3
scala> 1.+(2)
res15: Int = 3
```
Int类中包含了多个重载的`+`方法,用于分别接收不同类型的参数。
![scala-int+](D:\BigData-Notes\pictures\scala-int+.png)
### 3.2 运算符优先级

BIN
pictures/scala-int+.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 29 KiB