大三寒假学习 spark学习 函数定义 函数的类型和值
函数字面量:
字面量包括整数字面量、浮点数字面量、布尔型字面量、字符字面量、字符串字面量、符号字面量、函数字面量和元组字面量
函数字面量可以体现函数式编程的核心理念:
- 在函数式编程中,函数是“头等公民”,可以像任何其他数据类型一样被传递和操作,也就是说,函数的使用方式和其他数据类型的使用方式完全一致了
- 这时,我们就可以像定义变量那样去定义一个函数,由此导致的结果是,函数也会和其他变量一样,开始有“值”
- 就像变量的“类型”和“值”是分开的两个概念一样,函数式编程中,函数的“类型”和“值”也成为两个分开的概念,函数的“值”,就是“函数字面量”
函数的类型和值:
定义函数最通用的方法是作为某个类或者对象的成员,这种函数被称为方法,其定义的基本语法为:
def 方法名(参数列表):结果类型={方法体}
示例:
def counter( value : Int ): Int={value += 1}
上面定义的函数的类型如下:
( Int ) => Int
- 括号中为参数列表中的类型,箭头后面为返回值的类型
- 参数列表中只有一个类型时,可以将括号省略,多个类型之间用逗号隔开
上面定义的函数的值为:
(value) => { value + 1 }//只有一条语句时大括号可以省略
“=>”前面的value是参数名,“=>”后面是具体的运算语句或表达式
现在我们通过定义一个变量来参考如何定义一个函数:
val num: Int = 5
我们按照上面的形式定义函数:
val counter: Int => Int = {( value ) => value += 1}
从上面可以看出,在Scala中,函数已经是“头等公民”,单独剥离出来了“值”的概念,一个函数“值”就是函数字面量。这样,我们只要在某个需要声明函数的地方声明一个函数类型,在调用的时候传一个对应的函数字面量即可,和使用普通变量一模一样