/**
* 函数式编程进阶:
* 一、函数和变量同样做为Scala语言的一等公民,函数能够直接赋值给变量
* 二、函数更经常使用的方式是匿名函数,定义的时候只须要说明输入参数的类型和函数体便可,不须要名称,
* 通常会把它赋值给变量,在Spark源码中大量存在
* 三、函数能够做为参数直接传递给函数,极大的简化了编程代码,在Java中须要经过callback来实现
* 这样的功能
* 四、当函数的返回类型是函数的时候,这就代表Scala函数实现了闭包,Scala函数实际上是类和对象,
* 因此,Scala的参数都做为了对象的成员!!!
* 五、Scala柯里化能很好的实现链式功能
*/编程
一:Scala函数编程进阶 一、函数赋值给变量 //把函数赋值给变量 val f = bigData _ f("Spark") //变量f其实也变成了函数 def bigData(name: String): Unit = { println("Hi, " + name) } 二、匿名函数定义 //匿名函数 val fun = (name: String) => println("Hi, " + name) fun("Kafka") 三、将函数传递给方法 //将函数传递给方法 def getName(func: String => Unit, name: String) = func(name) getName(fun, "Scala") //map中其实也是个函数,map(item=>item*2) Array(1 to 10: _*).map(_ * 2).foreach(println) 四、Currying定义 def funcResult(message: String) = (name: String) => println(message + ": " + name) //funcResult("Java") //这样返回的是函数 funcResult("Hello")("Java") //Currying函数写法 //等同于 val result = funcResult("Hello") result("Java")