【Scala】(四)Scala 基础之变量、数据类型

简介: 【Scala】(四)Scala 基础之变量、数据类型

文章目录


一、Scala变量使用说明


二、数据类型


三、值类型转换

1、值类型隐式转换

2、强制类型转换


一、Scala变量使用说明


变量声明基本语法


var | val 变量名 [: 变量类型] = 变量值


注意事项


声明变量时,类型可以省略(编译器自动推导,即类型推导)


类型确定后,就不能修改,说明Scala 是强数据类型语言


在声明/定义一个变量时,可以使用var 或者 val 来修饰, var 修饰的变量可改变,val 修饰的变量不可改


val修饰的变量在编译后,等同于加上final, 通过反编译看下底层代码


var 修饰的对象引用可以改变,val 修饰的则不可改变,但对象的状态(值)却是可以改变的。(比如: 自定义对象、数组、集合等等)


变量声明时,需要初始值


二、数据类型


scala数据类型介绍


Scala 与 Java有着相同的数据类型,在Scala中数据类型都是对象,也就是说scala没有java中的原生类型


Scala数据类型分为两大类 AnyVal(值类型) 和 AnyRef(引用类型), 注意:不管是AnyVal还是AnyRef 都是对象


相对于java的类型系统,scala要复杂些!也正是这复杂多变的类型系统才让面向对象编程和函数式编程完美的融合在了一起


20191224232624626.png


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


Unit类型、Null类型和Nothing类型


1.Null是所有引用类型的子类型,而Nothing是所有类型的子类型。Null类只有一个实例对象,null,类似于Java中的null引用。null可以赋值给任意引用类型,但是不能赋值给值类型。


2.Nothing,可以作为没有正常返回值的方法的返回类型,非常直观的告诉你这个方法不会正常返回,而且由于Nothing是其他任意类型的子类,他还能跟要求返回值的方法兼容。


3.Unit类型用来标识过程,也就是没有明确返回值的函数。 由此可见,Unit类似于Java里的void。Unit只有一个实例,(),这个实例也没有实质的意义。


20191225183710421.png


使用细节和注意事项


Null类只有一个实例对象,null,类似于Java中的null引用。null可以赋值给任意引用类型(AnyRef),但是不能赋值给值类型(AnyVal: 比如 Int, Float, Char, Boolean, Long, Double, Byte, Short)


Unit类型用来标识过程,也就是没有明确返回值的函数。由此可见,Unit类似于Java里的void。Unit只有一个实例,(),这个实例也没有实质的意义


Nothing,可以作为没有正常返回值的方法的返回类型,非常直观的告诉你这个方法不会正常返回,而且由于Nothing是其他任意类型的子类,他还能跟要求返回值的方法兼容。


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

image.png


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


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


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


三、值类型转换


值类型隐式转换


介绍


当Scala程序在进行赋值或者运算时,精度小的类型自动转换为精度大的数据类型,这个就是自动类型转换(隐式转换)。


数据类型按精度(容量)大小排序为


20191225183942965.png


1、值类型隐式转换


自动类型转换细节说明


有多种类型的数据混合运算时,系统首先自动将所有数据转换成容量最大的那种数据类型,然后再进行计算。 5.6 + 10 = 》double

当我们把精度(容量)大 的数据类型赋值给精度(容量)小 的数据类型时,就会报错,反之就会进行自动类型转换。

(byte, short) 和 char之间不会相互自动转换。

byte,short,char 他们三者可以计算,在计算时首先转换为int类型。

自动提升原则: 表达式结果的类型自动提升为 操作数中最大的类型


2、强制类型转换


介绍


自动类型转换的逆过程,将容量大的数据类型转换为容量小的数据类型。使用时要加上强制转函数,但可能造成精度降低或溢出,格外要注意。


强制类型转换细节说明


当进行数据的 从 大——>小,就需要使用到强制转换

强转符号只针对于最近的操作数有效,往往会使用小括号提升优先级

Char类型可以保存 Int的常量值,但不能保存Int的变量值,需要强转

Byte和Short类型在进行运算时,当做Int类型处理

目录
相关文章
|
6天前
|
IDE Java 编译器
scala的两种变量类型 var 和 val
scala的两种变量类型 var 和 val
51 2
scala的两种变量类型 var 和 val
|
6天前
|
Java 编译器 API
Scala学习--day01变量与数据类型、运算符
Scala学习--day01变量与数据类型、运算符
|
6天前
|
存储 Scala
Scala变量和数据类型
Scala变量和数据类型
30 1
|
6天前
|
Java Shell API
Scala入门【变量和数据类型】
Scala入门【变量和数据类型】
|
分布式计算 Java 编译器
Scala快速入门-1-声明变量
因为Spark是由Scala开发的,所以在开发Spark应用程序之前要对Scala语言学习。虽然Spark也支持Java、Python语言,但是作为一名Java程序猿,还是决定要学习Scala哈。 Scala是运行在JVM上一门语言。开发效率非常高、语法丰富简洁,三两行Scala代码能搞定Java要写的一大坨代码。 Scala的语法糖太甜~~
|
Java 编译器 Shell
scala中的变量、方法、函数
Scala是一门多范式的编程语言,一种类似java的编程语言,是可扩展语言,并集成面向对象编程和函数式编程的各种特性的混合功能编程语言。 Scala被编译后在Java虚拟机上运行。
176 0
scala中的变量、方法、函数
|
Scala
Scala Lazy 惰性加载变量 你知道吗?
Scala Lazy 惰性加载 原写法;
92 0
|
Java 编译器 Scala
Scala 变量的注意事项|学习笔记
快速学习 Scala 变量的注意事项。
68 0
Scala 变量的注意事项|学习笔记
|
Java 编译器 Scala
Scala 变量的基本使用|学习笔记
快速学习 Scala 变量的基本使用。
76 0
Scala 变量的基本使用|学习笔记
|
6天前
|
SQL 存储 分布式计算
在scala中使用spark
在scala中使用spark
7 0