学习Spark--(6)--高阶函数

Scala高级特性

1. 高阶函数

--1--概念

Scala混合了面向对象和函数式的特性,我们通常将可以作为参数传递到方法中的表达式叫做函数。在函数式编程语言中,函数是“头等公民”,把函数作为参数或者是返回值是函数叫高阶函数。

高阶函数包含:作为值的函数、匿名函数、闭包、柯里化等等。

--2-- 作为值的函数

可以像任何其他数据类型一样被传递和操作的函数,每当你想要给算法传入具体动作时这个特性就会变得非常有用。

/**
  * 作为值的函数
  */
object MyFunction {
  def main(args: Array[String]): Unit = {
    //定义一个数组
    val arr: Array[Int] = Array(1, 2, 3, 4)
    //定义一个函数并将函数复制给fun1
    val fun1 = (x: Int) => {
      x * 2
    }
    //同过map方法把调用fun1函数
    val map: Array[Int] = arr.map(fun1)

    map.foreach(line => {
      println(line)
    })
  }
}

定义函数时格式:val 变量名 = (输入参数类型和个数) => 函数实现和返回值类型

=”表示将函数赋给一个变量

=>”左面表示输入参数名称、类型和个数,右边表示函数的实现和返回值类型

--3--匿名函数

在scala中,不需要给每一个函数命名,没有将函数赋值给变量的函数叫做匿名函数

object anonFunction {
  def main(args: Array[String]): Unit = {
    //定义一个数组
    val arr: Array[Int] = Array(1, 2, 3, 4)
    //map里面的就是匿名函数
    val map: Array[Int] = arr.map((x: Int) => {
      x * 2
    })
    map.foreach(line => {
      println(line)
    })
  }
}

由于Scala可以自动推断出参数的类型,所以还可以精简为

//map里面的就是匿名函数
val map: Array[Int] = arr.map(x => {
  x * 2
})
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值