Currying 复杂的函数式编程,可以维护变量在内存中的状态,且实现返回函数的链式功能,实现非常复杂的算法逻辑
1.函数和变量是scala中的一等公民,函数可以赋值给变量
2.函数更常用的是匿名函数,如果需要使用,则赋值给变量(其实是val常量)
3.函数作为函数的参数传递
4.函数作为函数的返回值,这是实现了闭包:实质是scala函数背后是类和对象,scala参数作为对象的成员
package kang
/*
Currying 复杂的函数式编程,可以维护变量在内存中的状态,且实现返回函数的链式功能,实现非常复杂的算法逻辑
1.函数和变量是scala中的一等公民,函数可以赋值给变量
2.函数更常用的是匿名函数,如果需要使用,则赋值给变量(其实是val常量)
3.函数作为函数的参数传递
4.函数作为函数的返回值,这是实现了闭包:实质是scala函数背后是类和对象,scala参数作为对象的成员
*/
object FunctionPrograming {
def main(args: Array[String]): Unit = {
/*
* 1.函数和变量是scala中的一等公民,函数可以赋值给变量
* 下面function_1和function_2例子,而且function_1可以写为function_2形式
*/
val function_1=getName ("zhi")
val function_2=getName _ //函数赋值给变量 _为占位符
function_2("kang")
/*
* 2.函数更常用的是匿名函数,如果需要使用,则赋值给变量(其实是val常量)
*/
val aa = (name:String) => println("name: "+name)//匿名函数赋值给变量
aa("康")
/*
* 3.函数作为函数的参数传递
*/
def fun_1( func:(String) => Unit , name:String){//函数作为函数的参数传递
func(name)
}
//
Array(1 to 10: _*).map( (item:Int) => 2*item ).foreach(x => println(" "+x))
//
def funcResult = (name:String) => println("name: "+name)
funcResult("kang_1")
//函数作为函数的返回值,这是实现了闭包:实质是scala函数背后是类和对象,scala参数作为对象的成员
def funcResult2(mesg:String) = (name:String) => println("mesg: "+mesg+" name: "+name)
funcResult2("hello! ")("kang_2")//Currying函数写法,等价于:下面两行(Currying 复杂的函数式编程,可以维护变量在内存中的状态,且实现返回函数的链式功能,实现非常复杂的算法逻辑)
// val result=funcResult2("hello! ")
// result("kang_2")
}
def getName(name:String){
println(name)
}
}