scala偏函数

前言

在Spark中会经常看见一种在Java中没有的语法(此处Java特指Java8+),类似下面这样子的:

pairs.filter{case (key, value) => value.length < 20}

在scala中函数是不支持元组作为参数的,因此就需要引入偏函数这个概念。

什么是偏函数

偏函数是一种可以对参数类型进行判断,从而选择合适的处理方式的语法。

偏函数的基本形式如下所示:

val pf2:PartialFunction[Any,String]={case d:Double=>"double"}

这里声明了一个偏函数变量,偏函数接收一个Double类型的参数,然后返回一个字符串"double"。

偏函数有什么用

使用偏函数,我们可以根据参数类型的不同选择不同的处理方式。

比如,下面这样

val mypf:PartialFunction[Any,String]={case d:Double=>"double";case s:String=>"String"}
printf("%5s %5s\n",mypf(1.5),mypf("abc"))

类比Java的Case用法,可知输出结果为"double String"。相比于多态来说,通过偏函数来实现,函数更加简洁。同时,偏函数不仅支持普通类型的参数,还支持元组类型的参数,相比于普通的函数来说适用范围更加广泛。

什么时候用偏函数

理论上来说,所有涉及到多态的情况都可以使用偏函数来简化代码。

另外,由于偏函数支持使用元组,因此偏函数可以应用于需要以元组作为函数参数的情况。例如在spark中PairRDD是通过元组的形式进行存储的。因此我们在遍历PairRDD的时候就必然需要用到偏函数来实现相关逻辑。

关于偏函数需要注意的事项

其实偏函数就是一种scala的简化语法,没有太多需要注意的地方。唯一需要注意的是,偏函数的参数类型不是必须的,如果我们不声明参数类型的话,那么就会接受所有的参数类型。

val mypf:PartialFunction[Any,String]={case a=>"any";case s:String=>"String";}
printf("%5s\n",mypf("abc"))

对于上面的例子,很明显对于case a这种情况,就是默认接收所有的参数。如果这个时候传入一个字符串,那么就会返回一个"any"字符串。后面的情况尽管也是符合的,但是由于函数已经返回了,所以后面的Case将不会执行。也就是意味着后面的代码将是没有用的。

关于这一点,在开发的时候需要特别注意。

原文地址:https://www.cnblogs.com/zhenlingcn/p/8298164.html

时间: 2024-10-12 19:52:21

scala偏函数的相关文章

Scala偏函数与部分函数

函数 1.部分函数 部分应用函数(Partial Applied Function)是缺少部分参数的函数,是一个逻辑上概念. def sum(x: Int, y: Int, z: Int) = x + y + z, 当调用sum的时候,如果不提供所有的参数,或者只提供某些参数时,比如sum _ , sum(3, _: Int, _:Int), sum(_: Int, 3, 4), 这样就生成了所谓的部分应用函数. 第一种形式(不推荐): 第一种定义形式: def sum(x: Int)(y: I

scala偏函数小栗子

package cn.beicaiqm.scala.day04 /** * Created by Administrator on 2018/6/1. * 被包在花括号内没有match的一组case语句是一个偏函数, * 它是PartialFunction[-A, +B]的一个实例,A代表参 * 数类型,B代表返回类型 */ object Demo09PartialFunction { def main(args: Array[String]) { println(getInfo(20)) pr

scala 偏函数

package com.jason.qianfeng object PartialFuncTest { def div: PartialFunction[Int, Int] = { case i if i != 0 => 100 / i } def r1: PartialFunction[Int, String] = { case 1 => "one" case 2 => "two" case _ => "other" }

王家林 大数据Spark超经典视频链接全集[转]

压缩过的大数据Spark蘑菇云行动前置课程视频百度云分享链接 链接:http://pan.baidu.com/s/1cFqjQu SCALA专辑 Scala深入浅出经典视频 链接:http://pan.baidu.com/s/1i4Gh3Xb 密码:25jc DT大数据梦工厂大数据spark蘑菇云Scala语言全集(持续更新中) http://www.tudou.com/plcover/rd3LTMjBpZA/ 1 Spark视频王家林第1课:大数据时代的“黄金”语言Scala 2 Spark视

Scala中的偏函数与部分应用函数

Scala中有PartialFunction的概念, 同时还要一个概念叫Partial Applied Function. 前者译作偏函数, 后者译作"偏应用函数"或"部分应用函数", 一字之差, 差距很大. 首先偏函数是个数学概念, 偏函数不是"函数"的一种, 而是一个跟函数平行的概念. Scala可以通过模式匹配来定义偏函数, 下面这两种方式定义的函数, 都可以认为是偏函数, 因为他们都只对其定义域Int的部分值做了处理. 那么像p1哪有定义

Scala 深入浅出实战经典 第67讲:Scala并发编程匿名Actor、消息传递、偏函数解析

王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 腾讯微云:http://url.cn/TnGbdC 360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2土豆:http://www.tudou.com/programs/view/LwsfuGIsWEk/优酷:http://v.youku.com/v_show/id_

scala并发编程原生线程Actor、Case Class下的消息传递和偏函数实战

参考代码: import scala.actors._ case class Person(name:String,age:Int) class HelloActor extends Actor{ def act(){ while(true){ receive{ case Person(name,age)=>{ //偏函数 println("Name: "+ name + ":" +"Age:" +age) sender ! "E

68:Scala并发编程原生线程Actor、Cass Class下的消息传递和偏函数实战解析及其在Spark中的应用源码解析

今天给大家带来的是王家林老师的scala编程讲座的第68讲:Scala并发编程原生线程Actor.Cass Class下的消息传递和偏函数实战解析 昨天讲了Actor的匿名Actor及消息传递,那么我们今天来看一下原生线程Actor及CassClass下的消息传递,让我们从代码出发: case class Person(name:String,age:Int)//定义cass Class class HelloActor extends Actor{//预定义一个Actor  def act()

Scala之偏函数Partial Function

本文原文出处: http://blog.csdn.net/bluishglc/article/details/50995939 严禁任何形式的转载,否则将委托CSDN官方维护权益! 从使用case语句构造匿名函数谈起 在Scala里,我们可以使用case语句来创建一个匿名函数(函数字面量),这有别于一般的匿名函数创建方法.来看个例子: scala> List(1,2,3) map {case i:Int=>i+1} res1: List[Int] = List(2, 3, 4) 这很有趣,ca