Scala的一等公民和至简原则

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

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

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

  • 方法和函数不建议写 return 关键字,Scala 会使用函数体的最后一行代码作为返回值;
  • 方法的返回值类型如果能够推断出来,那么可以省略,如果有 return 则不能省略返回值类型,必须指定;
  • 因为函数是对象,所以函数有类型,但函数类型可以省略,Scala 编译期可以自动推断类型;
  • 如果方法明确声明了返回值为 Unit,那么即使方法体中有 return 关键字也不起作用;
  • 如果方法的返回值类型为 Unit,可以省略等号 = ;
  • 如果函数的参数类型如果能够推断出来,那么可以省略;
  • 如果方法体或函数体只有一行代码,可以省略花括号 {} ;
  • 如果方法无参,但是定义时声明了 () ,调用时小括号 () 可省可不省;
  • 如果方法无参,但是定义时没有声明 () ,调用时必须省略小括号 () ;
  • 如果不关心名称,只关心逻辑处理,那么函数名可以省略。也就是所谓的匿名函数;
  • 如果匿名函数只有一个参数,小括号 () 和参数类型都能省略,没有参数或参数超过一个的情况下不能省略 ();
  • 如果参数只出现一次,且方法体或函数体没有嵌套使用参数,则参数可以用下划线 _ 来替代。
相关推荐
小伍_Five3 天前
Spark实战能力测评模拟题精析【模拟考】
java·大数据·spark·scala·intellij-idea
黄雪超3 天前
DataStreamAPI实践原理——快速上手(实操详细版)
大数据·flink·scala
白总Server4 天前
C++语法架构解说
java·网络·c++·网络协议·架构·golang·scala
vortex55 天前
Perl One-liner 数据处理——基础语法篇【匠心】
开发语言·scala·perl
老兵发新帖7 天前
Coursier:安装sbt
scala
请你喝好果汁64110 天前
indel_snp_ssr_primer
大数据·开发语言·scala
MZWeiei13 天前
Spark 中,map和foreach的区别
大数据·分布式·spark·scala
MZWeiei14 天前
区分:union(),coalesce () 和 repartition ()
大数据·分布式·spark·scala
北漂老男孩14 天前
Scala与Spark:原理、实践与技术全景详解
大数据·开发语言·spark·scala·学习方法
MZWeiei14 天前
Spark 中,创建 DataFrame 的方式(Scala语言)
大数据·分布式·spark·scala