Scala的一等公民和至简原则

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

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

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

  • 方法和函数不建议写 return 关键字,Scala 会使用函数体的最后一行代码作为返回值;
  • 方法的返回值类型如果能够推断出来,那么可以省略,如果有 return 则不能省略返回值类型,必须指定;
  • 因为函数是对象,所以函数有类型,但函数类型可以省略,Scala 编译期可以自动推断类型;
  • 如果方法明确声明了返回值为 Unit,那么即使方法体中有 return 关键字也不起作用;
  • 如果方法的返回值类型为 Unit,可以省略等号 = ;
  • 如果函数的参数类型如果能够推断出来,那么可以省略;
  • 如果方法体或函数体只有一行代码,可以省略花括号 {} ;
  • 如果方法无参,但是定义时声明了 () ,调用时小括号 () 可省可不省;
  • 如果方法无参,但是定义时没有声明 () ,调用时必须省略小括号 () ;
  • 如果不关心名称,只关心逻辑处理,那么函数名可以省略。也就是所谓的匿名函数;
  • 如果匿名函数只有一个参数,小括号 () 和参数类型都能省略,没有参数或参数超过一个的情况下不能省略 ();
  • 如果参数只出现一次,且方法体或函数体没有嵌套使用参数,则参数可以用下划线 _ 来替代。
相关推荐
q5673152312 小时前
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
开发语言·爬虫·python·自动化·scala
渣渣盟2 天前
Spark自定义累加器实现高效WordCount
大数据·spark·scala
IvanCodes3 天前
一、Scala 基础语法、变量与数据类型
大数据·开发语言·scala
q567315234 天前
Nim轻量级爬虫:异步高效+代理轮换防封
开发语言·后端·爬虫·typescript·scala
哈哈很哈哈4 天前
Scala协变、逆变、上界/下界、隐式参数、隐式转换
开发语言·后端·scala
更深兼春远17 天前
spark+scala安装部署
大数据·spark·scala
还是大剑师兰特20 天前
Scala面试题及详细答案100道(11-20)-- 函数式编程基础
scala·大剑师·scala面试题
华科云商xiao徐1 个月前
响应式爬虫系统设计:Scala异步任务编排与弹性容错机制
爬虫·scala
ChipCamp1 个月前
Chisel芯片开发入门系列 -- 18. CPU芯片开发和解释8(流水线架构的代码级理解)
开发语言·青少年编程·fpga开发·scala·dsp开发·risc-v·chisel
渣渣盟1 个月前
Flink从Kafka读取数据的完整指南
flink·kafka·scala