Scalascala函数
文章目录
- 函数
- 定义函数
- 方法和函数的区别
- 方法转换为函数
函数
scala支持函数式编程,将来编写Spark/Flink程序中,会大量使用到函数
定义函数
语法
val 函数变量名 = (参数名:参数类型, 参数名:参数类型....) => 函数体
- 函数是一个对象(变量)
- 类似于方法,函数也有输入参数和返回值
- 函数定义不需要使用def定义
- 无需指定返回值类型
参考代码
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)Intscala> val a = add
<console>:14: error: missing arguments for method addbb;
follow this method with `_' if you want to treat it as a partially applied functionval a = add
方法转换为函数
- 有时候需要将
方法转换为函数
,作为变量传递,就需要将方法转换为函数 - 使用
_
即可将方法转换为函数
参考代码
scala> def add(x:Int,y:Int)=x+y
add: (x: Int, y: Int)Intscala> val a = add _
a: (Int, Int) => Int = <function2>
Scalascala函数
文章目录
- 函数
- 定义函数
- 方法和函数的区别
- 方法转换为函数
函数
scala支持函数式编程,将来编写Spark/Flink程序中,会大量使用到函数
定义函数
语法
val 函数变量名 = (参数名:参数类型, 参数名:参数类型....) => 函数体
- 函数是一个对象(变量)
- 类似于方法,函数也有输入参数和返回值
- 函数定义不需要使用def定义
- 无需指定返回值类型
参考代码
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)Intscala> val a = add
<console>:14: error: missing arguments for method addbb;
follow this method with `_' if you want to treat it as a partially applied functionval a = add
方法转换为函数
- 有时候需要将
方法转换为函数
,作为变量传递,就需要将方法转换为函数 - 使用
_
即可将方法转换为函数
参考代码
scala> def add(x:Int,y:Int)=x+y
add: (x: Int, y: Int)Intscala> val a = add _
a: (Int, Int) => Int = <function2>
发布评论