好程序员大数据学习路线分享Scala分支和循环
2019-09-02 17:22
981 查看
好程序员大数据学习路线分享Scala分支和循环
3.3. 条件表达式
表达式:一个具有执行结果的代码块。结果是具体的值或者()
表达式的思考方式:以表达式为中心的编程思想
1.表达式和语句的区别:表达式有返回值,语句被执行。表达式一般是一个语句块,执行后,返回一个值
2.不使用return语句,最后一个表达式即返回值
if/else表达式有值,这个值就是跟在if或者else之后的表达式的值
object ConditionDemo {
def main(args: Array[String]){
var x = 1
//将if/else表达式值赋给变量y
val y = if (x > 0 ) 1 else -1
println(y)
//支持混合型表达式 //返回类型是Any val z = if(x>0) "success" else -1 println(z) //如果缺失else,相当于if(x>2) 1 else () //返回类型是AnyVal //如果进行类型判断和转换,可以使用: //var b = if(m.isInstanceOf[Int]) m.asInstanceOf[Int] else 0 val m = if(x>2) 1 println(m) //在scala中,每个表达式都有值,scala中有个unit类,写作(),相当于Java中的 void val n = if(x>2) 1 else () println(n) //if 嵌套 val k= if(x<0) 0 else if (x>=1) 1 else -1 println(k)
}
执行结果:
Scala的的条件表达式比较简洁,例如:
注意:1,每个表达式都有一个类型
2,条件表达式有值
3,混合型表达式,结果是Any或者AnyVal
4,scala没有switch语句
3.4. 块表达式
object BlockExpressionDemo {
def main(args: Array[String]){
var x = 0 //在scala中,{}中可以包含一系列表达式,块中最后一个表达式的值就是块的值 val res = { if (x < 0) { -1 } else if (x >= 1) { 1 } else { "error" } } println(res) val x0 = 1 val y0 = 1 val x1 = 2 val y1 = 2 val distance = { val dx = x1 - x0 val dy = y1 - y0 Math.sqrt(dx*dx+dy*dy) } println(distance) //块语句,最后一句是赋值语句,值是unit类型的 var res2 = { val dx = x1 - x0 val dy = y1 - y0 val res = Math.sqrt(dx*dx+dy*dy) } println(res2)
}
}
执行结果:
注意:
1,块表达式的值是最后一个表达式的值
2,赋值语句的值是unit类型的,
3.5. 循环
在scala中有for循环和while循环,用for循环比较多
for循环语法结构:for (i <- 表达式/数组/集合)
while (条件语句){表达式}
do{ 表达式}while()
object ForDemo
def main(args: Array[String]){
//每次循环将区间的一个值赋给i
for( i <- 1 to 10)
println(i)
//for i <-数组 val arr = Array("a", "b", "c") for( i <- arr) println(i) val s = "hello" for(i <- 0 until s.length){ println(s(i)) } // 或者 // for(c <- s)println(c) // 或者 // for(i <- 0 until s.length){ // println(s.charAt(i)) //使用了隐式转换,把字符串变成一个ArrayCharSequence // } //高级for循环 for(i <- 1 to 3 ; j<- 1 to 3 if i != j) print((10*i + j) + "") println() //for推导式,如果for循环的循环体以yeild开始,则该循环会构建出一个集合或者数组,每次迭代生成其中的一个值。 val v= for ( i <- 1 to 10 )yield i*10 println (v) //也可以借助函数由初始数组生成一个新的数组 val arr1 = Array(1,2,3,4,5,6,7,8,9) val arr2 = arr.map(_*10) val arr3 = arr.filter(_%2==0)
}
}
相关文章推荐
- 好程序员大数据学习路线分享hive的运行方式
- 好程序员大数据学习路线分享hive的运行方式
- 学习Python第三天--简单数据、操作符、分支和循环一些小理解
- 分享大数据学习路线导图、让你潜移默化的了解并入门大数据
- 好程序员Java学习路线分享三大特性之多态
- 好程序员Java学习路线分享SpringMVC之MVC概述
- scala 学习笔记(01) 函数定义、分支、循环、异常处理、递归
- 好程序员大数据学习路线之hive存储格式
- scala 学习笔记(01) 函数定义、分支、循环、异常处理、递归
- 大数据学习路线图,都是网上找的资料,分享下。如有问题,请及时联系更正
- 神级程序员大佬分享给python小白入门教程及学习路线,涨知识啦!
- 我的自学之路:大数据学习路线图分享
- 分享一下大数据的学习路线(哈哈)
- 数据分析初学者:数据分析入门学习路线分享
- 好程序员Java学习路线分享冒泡排序及优化
- 好程序员大数据学习路线之hive表的查询
- 大牛程序员分享html5入门学习路线顺序
- 好程序员Java学习路线分享JDBC初体验
- 好程序员云计算学习路线分享查看进程process
- 好程序员大数据学习路线hive内部函数