2.scala控制结构、函数、异常处理
2.scala控制结构、函数、异常处理
2.1条件表达式
(1)if表达式有返回值,如val result = if(x>0) 0 else -1 ,则result值可能为0或-1
(2)if表达式分支语句返回值的类型不一致时,则表达式返回值的类型是它们共同的父类型Any
val result = if(x>0) 0 else "error"
则result的类型为Any
(3)若if表达式没有分支满足条件,则返回Unit
2.2块表达式
(1)块表达式的值是最后一个语句的返回值,一个块中有多个语句时用逗号隔开。如:
val result = {val x=2;val y=3;pow(x,y)}
2.3循环
(1)while循环的实现方式和java中一样。
(2)scala中的for循环写法如下:
for(i <- 1 to 10){ println(i) }
(3)for推导式。如果for循环的循环体以yield开始,则该循环会构造出一个集合,每次迭代生成集合中的一个值,如:
for(i <- 1 to 10) yield i%3 //得到Vector(1,2,0,1,2,0,1,2,0,1)
2.4函数
一个函数包含了函数名称,参数和函数体等三个元素,如:
def abs(x:Double) = if(x>=0) x else -x
如果不是递归函数,不需要给定返回值类型
2.5参数
(1)默认参数。调用某些函数时可以不用给出参数,此时使用默认参数。如:
def check(path:String,name:String="home")
使用check("local")时传入的两个参数分别为local和默认的home
(2)带名参数。在提供参数值的时候指定参数名,带名参数可以打乱参数列表的顺序,但是带名参数和不带名参数共同使用时,需要将不带名参数放在带名参数之前。
(3)变长参数。参数列表可以为同类型的多个参数。如:
def sum(num:Int*)={ val count = 0 for(i <-num){ count +=i } }
函数得到的是一个序列,但是不代表可以传入一个序列。如sum(1 to 5)这种写法是错误的。
2.6懒值
当val被生命为lazy时,它的初始化会被推迟,直到其被第一次取值时。如:
val a = 0 lazy val b = a*10
2.7异常处理
scala中异常处理与java类似。一般写法如下:
try{ process }catch{ case e:Throwable => some process case _ => other process }finally{ }
转载于:https://www.cnblogs.com/bigdataer/p/6379734.html
2.scala控制结构、函数、异常处理相关推荐
- scala 字符串函数_Scala中的字符串chomp(或chop)函数
scala 字符串函数 剁或剁弦 (Chop or Chomp string) It is used to chop off the end of line characters. For this ...
- Scala基础 - 函数和方法的区别
2019独角兽企业重金招聘Python工程师标准>>> 1. 函数和方法 在Scala中函数是一等公民,你可以像操作数字一样将函数赋值给一个变量.使用val语句可以定义函数,def语 ...
- Scala:函数与匿名函数
Scala:函数与匿名函数 函数是第一等公民 函数类型 高阶函数 匿名函数 函数是第一等公民 在scala中,函数是第一等公民 Scala中,函数和变量有同等的位置,或者说函数也是一种变量. Scal ...
- Scala 优雅的异常处理之 try 与 Try
Scala 优雅的异常处理之 try 与 Try java将所有的错误封装为Throwable,Throwable下有两个子类:Error和Exception.scala本质上和java一样,都是运行 ...
- 2021年大数据常用语言Scala(三十四):scala高级用法 异常处理
目录 异常处理 捕获异常 抛出异常 异常处理 Scala中 无需在方法上声明异常 来看看下面一段代码. def main(args: Array[String]): Unit = {val i = 1 ...
- Scala定义函数的5种方式
大数据spark的源码是用scala来开发的,因此学习scala来开发spark会更加便捷. Scala中第一函数的接种方式如下: 规范化写法,scala函数的返回值是最后一行代码 Unit是scal ...
- scala 函数中嵌套函数_如何在Scala中将函数转换为部分函数?
scala 函数中嵌套函数 First, let's see what is a function and a partial function, and then we will see their ...
- scala定义函数(六)
大数据spark的源码是用Scala来开发的,因此学习Scala来开发spark会更加便捷. scala中第一函数的集中方式如下: 1.规范化写法,scala 函数的返回值是最后一行代码: def a ...
- scala的函数化编程
映射Map-构建Map 构造不可变映射 val map1=Map("Alice"->10,"Bob"->20,"Kotlin"- ...
最新文章
- hook情况下,解决内联没有:hover的方案
- Python零基础自学会有哪些弊端
- 我的C++笔记(数据的共享与保护)
- 我愿意参加计算机俱乐部的英文,如果你是一英语俱乐部的负责人你会组织什么活动...
- 判断变量定义和变量为空问题
- CreateThread()与beginthread()的区别详细解析
- 前端工程化系列好文摘要
- MYSQL中只知表名查询属于哪个SCHEMA
- 2021-10-28 python爬虫学习
- mybatis plus使用雪花算法_11.雪花算法与精度丢失
- java old区_一次Jvm old过高的排查过程实战记录
- duilib加载xml以及资源文件的路径问题
- 校学 离散数学主析取合取范式 做题心得
- 社交媒体与社会网络分析,深度分析社交网络问题
- Linux align函数,linux内核中ALIGN解析(示例代码)
- 培训三天敏捷我懂了这些
- python编号/排序/翻转/并行迭代使用场景及作用
- Swift--调用系统导航Apple map
- python 有限域函数库_python – Sympy:在有限域中求解矩阵
- 轻信别人可以“包装”,规避限购政策购房,会有那些后果?
热门文章
- Scala 方法参数列表是val 不可修改
- Hibernate一级缓存常用API
- eclipse出现updating error reports database一直运行解决方案
- 【小米校招笔试】给定一些线段,线段有起点和终点,求这些线段的覆盖长度,重复的部分只计算一次
- 删除github上某个release/tag
- linux ksh怎么查找僵尸进程,Unix 进程管理
- oracle游标指针移动时机,oracle--游标(cursor)
- android image 位移动画_深入理解Android之动画
- 华为交换机导入配置_华为交换机基础配置1—进入命令行
- python有几种打开方式_Python中几个以“__”开头的方法介绍总结