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,则执行该语句块
}elseif(布尔表达式2){
如果布尔表达式2为true,则执行该语句块
}elseif(布尔表达式3){
如果布尔表达式3为true,则执行该语句块
}else{
如果以上条件都为false,则执行该语句块
}
if…else 嵌套语句的语法格式如下:
if(布尔表达式1){
如果布尔表达式1为true,则执行该语句块
if(布尔表达式2){
如果布尔表达式2为true,则执行该语句块
}}elseif(布尔表达式3){
如果布尔表达式3为true,则执行该语句块
elseif(布尔表达式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方法的定义格式如下:
deffunctionName([参数列表]):[returntype]={
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大数据分析的内容,有什么问题欢迎评论区留言指正噢,我们下章再见 ~
版权归原作者 不吃泡面. 所有, 如有侵权,请联系我们删除。