Scala的基础语法
文章目录
1.声明值和变量
Scala有两种类型的变量:
-
关键字
var
声明的变量,
值是可变的
; -
关键字
val
声明的变量,也叫常量,
值是不可变的
;
var myvar:String="love" // 使用var声明变量myvar
val myval:Int=10 // 使用val变量声明myval
注意事项:
-
Scala中的变量在声明时必须进行初始化
。但使用var声明的变量可在初始化后再次对变量进行赋值,而使用val声明的常量的值不可被再次赋值。 -
声明变量时,可不给出变量的类型
,因为在初始化的时候,Scala的类型推断机制能够根据变量初始化的值自动推断出来。
与上述声明变量myvar和myval等同的代码:
var myvar="love" // 使用var声明变量myvar
val myval=10 // 使用val变量声明myval
-
使用关键字 var 或 val 声明变量时,后面紧跟的
变量名称不能和Scala中保留字重名
,而且变量可以以字母或下画线开头,且变量名是严格区分大小写的。
代码示范:
2.数据类型
Scala中的所有制都属于某种类型,包括数值和函数
。
Any是所有类型的超类型,也称为顶级类型,它包含2个直接子类:
-
AnyVal
:表示
值类型
,值类型描述的数据是一个不为空的值,而不是一个对象。它预定义了9种类型,分别是 Double、Float、Long、Int、Short、Btye、Unit、Char和Boolean。其中,Unit是一种不代表任何意义的值类型,它的作用类似Python中的 pass。 -
AnyRef
:表示
引用类型
。除值类型外,所有类型都继承自AnyRef。
在Scala数据类型层级结构的底部,还有2个数据类型,分别是
Nothing
和
Null
,具体介绍如下:
-
Nothing
:
所有类型的子类型,也称为底部类型
。它常见的用途是发出终止信号,如抛出异常、退出程序或者无限循环。 -
Null
:
所有引用类型的子类型
,它的主要用途是与其他JVM语言互操作,几乎不在Scala代码中使用。
3.算术和操作符重载
Scala中算术操作符(+、-、*、/、%)的作用和Python是一样的,位操作符(&、|、>>、<<)的作用也是一样的。特别强调的是
Scala的这些操作符是方法。
具体示范代码如下:
上述代码中,a.+(b) 中的符号 + 表示的是方法名。Scala中几乎可以用任何符号位Scala方法命名。
Scala与 java 和 python 有一个明显的不同之处是
Scala没有提供操作符++ 和 –
;如果想实现递增或者递减的效果,
可以使用“ + =1 ”或者“ – =1 ”来实现
。
4.控制结构语句
在Scala中,控制结构语句包括
条件分支语句
和
循环语句
。
- 条件分支语句:if 语句、if…else 语句、if…else if…else 语句、if…else嵌套语句;
- 循环语句:for 循环、while 循环 和 do…while循环;
4.1条件分支语句
if 语句
的语法格式如下:
if(布尔表达式){
如果布尔表达式为true,则执行该语句块
}
if…else 语句
的语法格式如下:
if(布尔表达式){
如果布尔表达式为true,则执行该语句块
}else{
如果布尔表达式为false,则执行该语句块
}
if…else if…else 语句
的语法格式如下:
if(布尔表达式1){
如果布尔表达式1为true,则执行该语句块
}else if(布尔表达式2){
如果布尔表达式2为true,则执行该语句块
}else if(布尔表达式3){
如果布尔表达式3为true,则执行该语句块
}else{
如果以上条件都为false,则执行该语句块
}
if…else 嵌套语句
的语法格式如下:
if(布尔表达式1){
如果布尔表达式1为true,则执行该语句块
if(布尔表达式2){
如果布尔表达式2为true,则执行该语句块
}
}else if(布尔表达式3){
如果布尔表达式3为true,则执行该语句块
else if(布尔表达式4){
如果布尔表达式4为true,则执行该语句块
}
}else{
如果以上条件都为false,则执行该语句块
}
案例演示:判断一个变量是否等于 5,如果是 5,则打印出 “a = 5”,如果不是 5,则判断该变量是否为10,如果是 10,则打印出 “a = 10”,否则打印出“ 无法判断a的值 ”;示例代码如下:
4.2循环语句
Scala中的for循环语句和Java、Python中的for循环语句在语法上有较大的区别。
for 循环语句
的语法格式:
for(变量<-表达式/数组/集合){ //箭头为大于符号"<"和减号"-"组成
循环语句;
}
示例:循环0到9,每循环一次将该值打印输出;
在Scala语法中,可以使用” 0 to 9 “表示0到9的范围,闭区间即包含首尾数,示例代码如下:
Scala在for循环语句中可以通过使用 if 判断语句过滤一些元素,多个过滤条件用
分号
分隔开。
例:输出 0 到 9 范围中大于5的偶数;示例代码如下:
Scala中的
while循环语句只要表达式为 true ,循环体就会重复执行
。
while循环语句
的语法格式如下:
while(布尔表达式){
循环语句;
}
例:假设有一个变量x=1,判断该变量是否小于10,如果是则打印输出,然后进行 +2 运算;示例代码如下:
do…while循环语句
的语法格式如下:
do{
循环语句;
}while(布尔表达式)
do…while循环语句与while语句主要区别是:
do…while语句的循环语句至少执行一次。
例:假设一个变量y=10,先打印输出,然后进行 +1 运算,再判断该变量是否小于20,如果是则进行循环;示例代码如下:
5.方法与函数
Scala的方法是类的一部分,而函数是一个对象可以赋值给一个变量。换句话说,
在类中定义的函数既是方法
。
Scala中可以使用
def
语句和
val
语句定义函数,而
定义方法只能使用 def 语句
。
5.1方法
Scala方法
的定义格式如下:
def functionName([参数列表]):[return type]={
function body
return[expr]
}
从上面代码可以看出,Scala的方法由多个部分组成:
-
def
:Scala的关键字,并且是固定不变的,一个方法的定义是由def关键字开始的; -
functionName
:Scala方法的方法名 -
([参数列表]):[return type]
:Scala方法的可选参数列表,参数列表中的每个参数都有一个名字,参数名后跟着冒号和参数类型 -
function body
:方法的主体 -
return[expr]
:Scala方法的返回类型,可以是任意合法的Scala数据类型,若无返回值,则返回类型为Unit。
例:定义一个方法add(),实现两个数相加求和;示例代码如下:
Scala的方法调用格式如下:
functionName(参数列表) //没有使用实例的对象调用方式
[instance.]functionName(参数列表) //方法由实例对象来调用
接上例调用:
5.2 函数
在Scala中,由于使用 def 语句定义以及调用函数的格式均与方法一样,然而,Scala函数与Scala方法还是有区别的,
可以使用 val 语句定义函数的格式,并且函数必须要有参数列表,而方法可以没有参数列表。
Scala 函数
的定义格式如下:
val functionName = ([参数列表])=>function body
例:定义一个函数addInt,实现两个整数相加求和;示例代码如下:
函数的调用跟方法一样:functionName(参数列表)
5.3 方法转换成函数
方法转换成函数的格式如下:
val 函数name = 方法name _
在上述的格式中,方法name后紧跟一个
空格
和
下划线
,是为了告知编译器将方法name转换成函数,而不是调用这个方法。
例:定义一个方法m,实现将方法m转成函数 f ;示例代码如下:
提示:Scala方法的返回值类型可以不写,编译器可以自动推断出来,但对于
递归函数
来说,
必须要指定返回类型
。
本博客到此就结束嘞,有帮助或学到东西的话,给个
点赞
支持一下吧,制作不易,我是不吃泡面,不知会写BUG,
关注
我,持续更新
Spark大数据分析
的内容,有什么问题欢迎评论区留言指正噢,我们下章再见 ~