spark学习日志<二>:条件控制与循环
来源:互联网 发布:snmpwalk用的什么端口 编辑:程序博客网 时间:2024/06/08 17:44
if表达式
·if表达式的定义:在Scala中,if表达式是有值的,就是if或者else中最后一行语句返回的值。
·例如,val age = 30; if (age > 18) 1 else 0
·可以将if表达式赋予一个变量
例如,val isAdult = if (age > 18) 1 else 0
·另外一种写法,var isAdult = -1; if(age > 18) isAdult = 1 else isAdult = 0,但是通常使用上一种写法
·if表达式的类型推断:由于if表达式是有值的,而if和else子句的值类型可能不同,此时if表达式的值是什么类型呢?Scala会自动进行推断,取两个类型的公共父类型。
·例如,if(age > 18) 1 else 0,表达式的类型是Int,因为1和0都是Int
·例如,if(age > 18) “adult” else 0,此时if和else的值分别是String和Int,则表达式的值是Any,Any是String和Int的公共父类型
·如果if后面没有跟else,则默认else的值是Unit,也用()表示,类似于java中的void或者null。
例如,val age = 12; if(age > 18) “adult”。此时就相当于if(age > 18) “adult” else ()。
·将if语句放在多行中:默认情况下,REPL只能解释一行语句,但是if表达式通常需要放在多行。
·可以使用{}的方式,比如以下方式,或者使用:paste和ctrl+D的方式。
if(age > 18) { "adult" } else if(age > 12) "teenager" else "children"
语句终结符、块表达式
·默认情况下,scala不需要语句终结符,默认将每一行作为一个语句
·一行放多条语句:如果一行要放多条语句,则必须使用语句终结符
·例如,使用分号作为语句终结符,var a, b, c = 0; if(a < 10) { b = b + 1; c = c + 1 }
·通常来说,对于多行语句,还是会使用花括号的方式
if(a < 10) {
b = b + 1
c = c + 1
}
·块表达式:块表达式,指的就是{}中的值,其中可以包含多条语句,最后一个语句的值就是块表达式的返回值。
·例如
,var d = if(a < 10) { b = b + 1; c + 1 }
输入和输出
·print和println:print打印时不会加换行符,而println打印时会加一个换行符。
·例如,print(“Hello World”); println(“Hello World”)
·printf:printf可以用于进行格式化
·例如,printf(“Hi, my name is %s, I’m %d years old.\n”, “Leo”, 30)
·readLine: readLine允许我们从控制台读取用户输入的数据,类似于java中的System.in和Scanner的作用。
·综合案例:游戏厅门禁
val name = readLine("Welcome to Game House. Please tell me your name: ")print("Thanks. Then please tell me your age: ")val age = readInt()if(age > 18) { printf("Hi, %s, you are %d years old, so you are legel to come here!", name, age)} else { printf("Sorry, boy, %s, you are only %d years old. you are illegal to come here!", name, age)}
循环
while do循环:Scala有while do循环,基本语义与Java相同。
var n = 10while(n > 0) { println(n) n -= 1}
·Scala没有for循环,只能使用while替代for循环,或者使用简易版的for语句
·简易版for语句:
var n = 10; for(i <- 1 to n) println(i)
·或者使用until,表式不达到上限:
for(i <- 1 until n) println(i)
也可以对字符串进行遍历,类似于java的增强for循环:
for(c <- "Hello World") print(c)
·跳出循环语句,scala没有提供类似于java的break语句,但是可以使用boolean类型变量、return或者Breaks的break函数来替代使用。
import scala.util.control.Breaks._breakable { var n = 10 for(c <- "Hello World") { if(n == 5) break; print(c) n -= 1 }}
高级for循环
·多重for循环:九九乘法表
for(i <- 1 to 9; j <- 1 to 9) { if(j == 9) { println(i * j) } else { print(i * j + " ") }}
·if守卫:取偶数
for(i <- 1 to 100 if i % 2 == 0) println(i)
·for推导式:构造集合
for(i <- 1 to 10) yield i
- spark学习日志<二>:条件控制与循环
- scala 条件循环与控制
- Shell脚本学习(二):条件语句与循环语句
- [Kotlin]Kotlin学习笔记(二):Kotlin中流程控制语句的学习(条件、跳转、循环)
- Python学习笔记-条件控制&循环
- Python循环与条件控制语句
- [Language]Python跳转控制--条件与循环
- C++/CLI学习入门(二):控制与循环 …
- shell 脚本编程学习(三) 条件控制,循环控制
- shell 条件控制,循环
- 条件循环控制语句
- Python3条件控制、循环控制
- Python3基础(四) 条件与循环控制
- Python语法第2讲:条件分支与循环控制
- shell学习二十七--循环控制命令
- C++/CLI(二):控制与循环
- JAVA学习(四):Java流程控制语句(顺序结构、if条件语句、switch条件语句、循环语句与跳转语句)
- 条件语句及控制循环
- Java 对象和类
- iOS 面试题--转自唐巧
- Fragment
- BorderContainer与ContentPane不能显示,解析不了
- 241. Different Ways to Add Parentheses
- spark学习日志<二>:条件控制与循环
- linux ar命令
- 几种指针的区别及用法
- 【数字图像处理】基于GDI的入门级YUV播放器设计
- HTML5中的video标签(无法显示画面)
- Qt实战开发-动态曲线图
- 如何结合Sping与Java封装自己的Exception?
- matlab中调用c++函数
- 使用 create-react-app 构建 react应用程序 (react-scripts)