大数据——Scala部分应用函数和偏函数及示例演示

Scala部分函数和偏函数及示例演示

部分应用函数

部分应用函数也称部分函数。当在调用一个函数时,把这个函数应用到参数中。 如果您传递所有预期的参数,则表示您已完全应用它。 如果只传递几个参数并不是全部参数,那么将返回部分应用的函数。这样就可以方便地绑定一些参数,其余的参数可稍后填写补上。

示例

object test {
  def main(args: Array[String]): Unit = {
    def showMsg(title:String,content:String,num:Int):Unit={
      println(title+":"+content+" "+num+"米")
    }
    showMsg("警告","当前水位",12)

    val title="提醒"
    def showWaterAlter=showMsg(title,_:String,_:Int)
    showWaterAlter("现在水位",20)
  }
}

结果展示:
在这里插入图片描述

偏函数

偏函数是只对函数定义域的一个子集进行定义的函数
PartialFunction[-A,+B]是一个特质

  • A为函数定义域,B为偏函数返回值类型
  • apply()
  • isDefinedAt()
//自定义偏函数
val inc = new PartialFunction[Any, Int] {
    def apply(any: Any) = any.asInstanceOf[Int]+1
    def isDefinedAt(any: Any) = 
                                  if (any.isInstanceOf[Int]) true else false
}
List(1,2,3,"four").collect(inc)

case语句

val pf:PartialFunction[Any, Int]={case x:Int=>x+1} //返回一个偏函数
List(1,2,3,"four").collect(pf)  //输出List(2,3,4)

示例

object test {
  def main(args: Array[String]): Unit = {
    def funPartional:PartialFunction[String,Int]={
      case "hello"=>1
      case "world"=>2
      case _=>0
    }
    val num1=funPartional("hello")
    val num2=funPartional("world")
    val num3=funPartional("gree")
    println(num1)
    println(num2)
    println(num3)
    val words=List("hello","world","gree","kn09")
    val ints:List[Int]=words.collect(funPartional)
    words.collect(funPartional).foreach(print)
    //等同于
    words collect funPartional foreach print

    def funTest:PartialFunction[String,Int]={
      case "male"=>1
      case "female"=>0
      case "男"=>1
      case "女"=>0
      case "m"=>1
      case "f"=>0
      case _=>6
    }
    val sexs=List("male","female","female","女","男","male","f","m","f","男男")
    sexs.collect(funTest).foreach(print)
  }
}

结果展示:
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值