第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")

备注:

资料来源于:DT_大数据梦工厂(Spark"蘑菇云"行动

更多私密内容,请关注微信公众号:DT_Spark

如果您对大数据Spark感兴趣,可以免费听由王家林老师每天晚上2000开设的Spark永久免费公开课,地址YY房间号:68917580


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值