2.scala控制结构、函数、异常处理---小书匠,在线编辑器,MARKDOWN,Evernote,文件版本

2.scala控制结构、函数、异常处理

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控制结构、函数、异常处理相关推荐

  1. scala 字符串函数_Scala中的字符串chomp(或chop)函数

    scala 字符串函数 剁或剁弦 (Chop or Chomp string) It is used to chop off the end of line characters. For this ...

  2. Scala基础 - 函数和方法的区别

    2019独角兽企业重金招聘Python工程师标准>>> 1. 函数和方法 在Scala中函数是一等公民,你可以像操作数字一样将函数赋值给一个变量.使用val语句可以定义函数,def语 ...

  3. Scala:函数与匿名函数

    Scala:函数与匿名函数 函数是第一等公民 函数类型 高阶函数 匿名函数 函数是第一等公民 在scala中,函数是第一等公民 Scala中,函数和变量有同等的位置,或者说函数也是一种变量. Scal ...

  4. Scala 优雅的异常处理之 try 与 Try

    Scala 优雅的异常处理之 try 与 Try java将所有的错误封装为Throwable,Throwable下有两个子类:Error和Exception.scala本质上和java一样,都是运行 ...

  5. 2021年大数据常用语言Scala(三十四):scala高级用法 异常处理

    目录 异常处理 捕获异常 抛出异常 异常处理 Scala中 无需在方法上声明异常 来看看下面一段代码. def main(args: Array[String]): Unit = {val i = 1 ...

  6. Scala定义函数的5种方式

    大数据spark的源码是用scala来开发的,因此学习scala来开发spark会更加便捷. Scala中第一函数的接种方式如下: 规范化写法,scala函数的返回值是最后一行代码 Unit是scal ...

  7. scala 函数中嵌套函数_如何在Scala中将函数转换为部分函数?

    scala 函数中嵌套函数 First, let's see what is a function and a partial function, and then we will see their ...

  8. scala定义函数(六)

    大数据spark的源码是用Scala来开发的,因此学习Scala来开发spark会更加便捷. scala中第一函数的集中方式如下: 1.规范化写法,scala 函数的返回值是最后一行代码: def a ...

  9. scala的函数化编程

    映射Map-构建Map 构造不可变映射 val map1=Map("Alice"->10,"Bob"->20,"Kotlin"- ...

最新文章

  1. hook情况下,解决内联没有:hover的方案
  2. Python零基础自学会有哪些弊端
  3. 我的C++笔记(数据的共享与保护)
  4. 我愿意参加计算机俱乐部的英文,如果你是一英语俱乐部的负责人你会组织什么活动...
  5. 判断变量定义和变量为空问题
  6. CreateThread()与beginthread()的区别详细解析
  7. 前端工程化系列好文摘要
  8. MYSQL中只知表名查询属于哪个SCHEMA
  9. 2021-10-28 python爬虫学习
  10. mybatis plus使用雪花算法_11.雪花算法与精度丢失
  11. java old区_一次Jvm old过高的排查过程实战记录
  12. duilib加载xml以及资源文件的路径问题
  13. 校学 离散数学主析取合取范式 做题心得
  14. 社交媒体与社会网络分析,深度分析社交网络问题
  15. Linux align函数,linux内核中ALIGN解析(示例代码)
  16. 培训三天敏捷我懂了这些
  17. python编号/排序/翻转/并行迭代使用场景及作用
  18. Swift--调用系统导航Apple map
  19. python 有限域函数库_python – Sympy:在有限域中求解矩阵
  20. 轻信别人可以“包装”,规避限购政策购房,会有那些后果?

热门文章

  1. Scala 方法参数列表是val 不可修改
  2. Hibernate一级缓存常用API
  3. eclipse出现updating error reports database一直运行解决方案
  4. 【小米校招笔试】给定一些线段,线段有起点和终点,求这些线段的覆盖长度,重复的部分只计算一次
  5. 删除github上某个release/tag
  6. linux ksh怎么查找僵尸进程,Unix 进程管理
  7. oracle游标指针移动时机,oracle--游标(cursor)
  8. android image 位移动画_深入理解Android之动画
  9. 华为交换机导入配置_华为交换机基础配置1—进入命令行
  10. python有几种打开方式_Python中几个以“__”开头的方法介绍总结