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"
  }

  def r2: PartialFunction[Int, String] = {
    case 1 => "one"
  }

  def r3: PartialFunction[Int, String] = {
    case 2 => "two"
  }

  def r4: PartialFunction[Int, String] = {
    case _ => "other"
  }

  def r6: PartialFunction[String, String] = {
    case "one" => "haha one"
    case "two" => "wawo two"
  }

  def main(args: Array[String]): Unit = {
    val s = "=" * 10
    println(s"$s test function div $s")
    println(s"div.isDefinedAt(0):" + div.isDefinedAt(0))
    println(s"div.isDefinedAt(1):" + div.isDefinedAt(1))
    println(s"div(2) = " + div(2))

    println(s"$s test function r1 $s")
    println(s"r1(2) = " + r1(2))

    println(s"$s orElse $s")
    val r5 = r2 orElse r3 orElse r4
    println(s"r5(2) = " + r5(2))

    println(s"$s  andThen $s")
    val r7: PartialFunction[Int, String] = r1 andThen r6
    println(s"r7(1) = " + r7(1))
  }
}

执行结果

========== test function div ==========
div.isDefinedAt(0):false
div.isDefinedAt(1):true
div(2) = 50
========== test function r1 ==========
r1(2) = two
========== orElse ==========
r5(2) = two
==========  andThen ==========
r7(1) = haha one

总结

1.什么是偏函数:例如上述的函数div,传入的参数为 int,反汉之也是int,但是函数并不是对所有输入的int都进行处理,而是只处理不为0 的int

2.orElse 方法可以拼接多个偏函数,类似if...else

3.andThen 方法是把多个偏函数串联起来,第一个函数的结果作为参数传给第二个,以此类推

原文地址:https://www.cnblogs.com/jason-dong/p/9581699.html

时间: 2024-08-05 18:31:03

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偏函数

前言 在Spark中会经常看见一种在Java中没有的语法(此处Java特指Java8+),类似下面这样子的: pairs.filter{case (key, value) => value.length < 20} 在scala中函数是不支持元组作为参数的,因此就需要引入偏函数这个概念. 什么是偏函数 偏函数是一种可以对参数类型进行判断,从而选择合适的处理方式的语法. 偏函数的基本形式如下所示: val pf2:PartialFunction[Any,String]={case d:Doubl

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

王家林 大数据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