Scala的一等公民和至简原则

1. Scala 中,函数是一等公民具体体现在哪里

  • Scala 混合了面向对象特性和函数式的特性
  • 函数可以作为值传递:函数可以作为参数传递给其他函数,也可以作为返回值返回给其他函数
  • 函数可以赋值给变量:和其他数据类型⼀样,函数也可以赋值给变量,变量的类型就是函数的类型
  • 函数可以嵌套定义:在函数内部可以定义另外⼀个函数,内部函数可以定义外部函数的变量
  • Scala支持匿名函数,可以直接定义并传递匿名函数

2. 说说 Scala 函数的至简原则

  • 方法和函数不建议写 return 关键字,Scala 会使用函数体的最后一行代码作为返回值;
  • 方法的返回值类型如果能够推断出来,那么可以省略,如果有 return 则不能省略返回值类型,必须指定;
  • 因为函数是对象,所以函数有类型,但函数类型可以省略,Scala 编译期可以自动推断类型;
  • 如果方法明确声明了返回值为 Unit,那么即使方法体中有 return 关键字也不起作用;
  • 如果方法的返回值类型为 Unit,可以省略等号 = ;
  • 如果函数的参数类型如果能够推断出来,那么可以省略;
  • 如果方法体或函数体只有一行代码,可以省略花括号 {} ;
  • 如果方法无参,但是定义时声明了 () ,调用时小括号 () 可省可不省;
  • 如果方法无参,但是定义时没有声明 () ,调用时必须省略小括号 () ;
  • 如果不关心名称,只关心逻辑处理,那么函数名可以省略。也就是所谓的匿名函数;
  • 如果匿名函数只有一个参数,小括号 () 和参数类型都能省略,没有参数或参数超过一个的情况下不能省略 ();
  • 如果参数只出现一次,且方法体或函数体没有嵌套使用参数,则参数可以用下划线 _ 来替代。
相关推荐
爱编程的王小美4 天前
Scala 入门指南
开发语言·后端·scala
旋风小飞棍4 天前
spark和hadoop的区别与联系
大数据·开发语言·scala
搞程序的心海8 天前
Flink 编程基础:Scala 版 DataStream API 入门
大数据·flink·scala
不要天天开心8 天前
Spark-SQL与Hive的连接及数据处理全解析
spark·scala
胡萝卜糊了Ohh9 天前
spark-sql
spark·scala
搞程序的心海10 天前
Flink DataStream API深度解析(Scala版):窗口计算、水位线与状态编程
大数据·flink·scala
WiKiLeaks_successor11 天前
Scala day4(tuple, set and map)
scala
胡萝卜糊了Ohh11 天前
scala
开发语言·后端·scala
QX_hao11 天前
【spark--scala】--环境配置
大数据·spark·scala