函数
scala支持函数式编程,将来在Spark/Flink程序中,会大量使用到函数
定义函数
语法
val 函数变量名 = (参数名:参数类型,参数名:参数类型......) => 函数体
注
函数是一个对象(变量)
类似于方法,函数也要输入参数和返回值
函数定义不需要使用 def 定义
无需指定返回值类型
示例
1.定义一个两个数值相加的函数
2.调用该函数
参考代码
scala> val add = (x:Int, y:Int) => x + y
add: (Int, Int) => Int = <function2>
scala> add(1,2)
res0: Int = 3
结果
方法和函数的区别
定义
方法是隶属于类或者对象的,在运行时,它是加载到JVM的方法区中
可以将函数对象赋值给一个变量,在运行时,它是加载到JVM的堆内存中
函数是一个对象