Scala实战高手****第12课:Scala函数式编程进阶(匿名函数、高阶函数、函数类型推断、Currying)与Spark源码鉴赏

/**
 * 函数式编程进阶:
 * 1、函数和变量一样作为Scala语言的一等公民,函数可以直接赋值给变量
 * 2、函数更常用的方式是匿名函数,定义的时候只需要说明输入参数的类型和函数体即可,不需要名称,
 * 一般会把它赋值给变量,在Spark源码中大量存在
 * 3、函数可以作为参数直接传递给函数,极大的简化了编程代码,在Java中需要通过callback来实现
 * 这样的功能
 * 4、当函数的返回类型是函数的时候,这就表明Scala函数实现了闭包,Scala函数其实是类和对象,
 * 所以,Scala的参数都作为了对象的成员!!!
 * 5、Scala柯里化能很好的实现链式功能
 */

一:Scala函数编程进阶
 
1、函数赋值给变量
 
    //把函数赋值给变量
    val f = bigData _
    f("Spark") //变量f其实也变成了函数
 
  def bigData(name: String): Unit = {
    println("Hi, " + name)
 
  }
 
2、匿名函数定义
 
    //匿名函数
    val fun = (name: String) => println("Hi, " + name)
    fun("Kafka")
 
3、将函数传递给方法
 
    //将函数传递给方法
    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)
 
4、Currying定义
 
    def funcResult(message: String) = (name: String) => println(message + ": " + name)
    //funcResult("Java") //这样返回的是函数
    funcResult("Hello")("Java") //Currying函数写法
    //等同于
    val result = funcResult("Hello")
    result("Java")

  

posted @ 2018-11-21 10:10  Mars、少年  阅读(154)  评论(0编辑  收藏  举报