0
点赞
收藏
分享

微信扫一扫

Scala入门_函数

耳一文 2022-02-16 阅读 144

函数

scala支持函数式编程,将来编写Spark/Flink程序中,会大量使用到函数

定义函数

语法

val 函数变量名 = (参数名:参数类型, 参数名:参数类型....) => 函数体



[!TIP]


  • 函数是一个对象(变量)
  • 类似于方法,函数也有输入参数和返回值
  • 函数定义不需要使用​​def​​定义
  • 无需指定返回值类型


示例


  1. 定义一个两个数值相加的函数
  2. 调用该函数

参考代码

scala> val add = (x:Int, y:Int) => x + y
add: (Int, Int) => Int = <function2>

scala> add(1,2)
res3: Int = 3

方法和函数的区别


  • 方法是隶属于类或者对象的,在运行时,它是加载到JVM的方法区中
  • 可以将函数对象赋值给一个变量,在运行时,它是加载到JVM的堆内存中
  • 函数是一个对象,继承自FunctionN,函数对象有apply,curried,toString,tupled这些方法。方法则没有

示例

方法无法赋值给变量

scala> def add(x:Int,y:Int)=x+y
add: (x: Int, y: Int)Int

scala> val a = add
<console>:12: error: missing argument list for method add
Unapplied methods are only converted to functions when a function type is expected.
You can make this conversion explicit by writing `add _` or `add(_,_)` instead of `add`.
val a = add

方法转换为函数


  • 有时候需要将方法转换为函数,作为变量传递,就需要将方法转换为函数
  • 使用​​_​​即可将方法转换为函数

示例


  1. 定义一个方法用来进行两个数相加
  2. 将该方法转换为一个函数,赋值给变量

参考代码

scala> def add(x:Int,y:Int)=x+y
add: (x: Int, y: Int)Int

scala> val a = add _
a: (Int, Int) => Int = <function2>


举报

相关推荐

0 条评论